



# 4.2 Megapixel machine vision CMOS image sensor



**Datasheet** 



### **Change record:**

| Issue | Date       | Modification                                                                                                     |  |  |  |
|-------|------------|------------------------------------------------------------------------------------------------------------------|--|--|--|
| 1     | 06/05/2009 | Origination                                                                                                      |  |  |  |
| 1.1   | 12/11/2009 | Corrected register address of sub_s[7:0] to '35' (p 29/30/33)                                                    |  |  |  |
| 1.2   | 11/01/2010 | Adjusted min input frequency (section 3.3)                                                                       |  |  |  |
| 1.3   | 14/01/2010 | Adjusted pin width in package drawing                                                                            |  |  |  |
| 2     | 29/03/2010 | Added spectral response                                                                                          |  |  |  |
|       | 25/05/2010 | Added spectral response for color devices                                                                        |  |  |  |
|       |            | Updated specifications for version 2 devices                                                                     |  |  |  |
|       |            | Changed VDD18 to VDD20                                                                                           |  |  |  |
|       |            | Added ordering info                                                                                              |  |  |  |
|       |            | Added handling and soldering procedures                                                                          |  |  |  |
|       |            | Removed "confidential" in footer                                                                                 |  |  |  |
|       |            | Added recommended and adjustable register settings                                                               |  |  |  |
| 2.1   | 22/7/2010  | Frame rate calculation added                                                                                     |  |  |  |
| 2.2   | 2/8/2010   | Read-out in 12 bit mode added                                                                                    |  |  |  |
| 2.3   | 1/9/2010   | Added exposure time offset (0.65 x register73 x clk_per x 129)                                                   |  |  |  |
| 2.4   | 17/9/2010  | Added Vtf_11 to GND remark                                                                                       |  |  |  |
| 2.5   | 19/10/2010 | Added E12 spectral response curve and part numbers                                                               |  |  |  |
| 2.6   | 11/01/2011 | Added RGB Bayer pattern details                                                                                  |  |  |  |
| 2.7   | 1/2/2011   | Added electrical IO specifications                                                                               |  |  |  |
| 2.8   | 25/3/2011  | Updated reflow soldering profile                                                                                 |  |  |  |
| 2.9   | 13/4/2011  | Changed tilt to 0.2 degrees, updated spectral response, changed                                                  |  |  |  |
|       |            | exposure time formula                                                                                            |  |  |  |
| 2.9.1 | 20/5/2011  | Changed 12 bit read-out mode (removed 16 and 8 outputs)                                                          |  |  |  |
| 3     | 1/9/2011   | Complete revision for version 3 sensor                                                                           |  |  |  |
| 3.1   | 24/05/2012 | Line up with v2.9.5 datasheet                                                                                    |  |  |  |
| 3.2   | 30/07/2012 | Added:                                                                                                           |  |  |  |
|       |            | - PLR Vlow2/3 enable bit                                                                                         |  |  |  |
|       |            | - Sampling of digital inputs on rising CLK_IN                                                                    |  |  |  |
|       |            | - Details on LVDS data out in multiplex modes                                                                    |  |  |  |
|       |            | <ul><li>CTR channel bits on Tdig1/2 pins</li><li>Evaluation kit available</li></ul>                              |  |  |  |
|       |            | - Minimum time between Frame_req pulses in internal mode                                                         |  |  |  |
|       |            | - Temperature sensor calibration example                                                                         |  |  |  |
|       |            | Updated:                                                                                                         |  |  |  |
|       |            | - Bayer pattern figure (pixel(0,0) green → red). No actual device                                                |  |  |  |
|       |            | change compared to previous devices.                                                                             |  |  |  |
|       |            | - Supply noise influence                                                                                         |  |  |  |
|       |            | - Control bit INTE1/2 (no FOT overlap)                                                                           |  |  |  |
|       |            | - FOT and Read-out time rounding                                                                                 |  |  |  |
|       |            | - Detailed timing of control channel figure                                                                      |  |  |  |
|       |            | - LVDS clock delay figure (CLK_IN period)  SPI timing from SPI unload to Frame, reg (1us → 1ms)                  |  |  |  |
|       |            | <ul> <li>SPI timing from SPI upload to Frame_req (1μs → 1ms)</li> <li>Total power use (600mW → 650mW)</li> </ul> |  |  |  |
|       |            | - Total power use (600mW → 650mW) - VDD33 power use (165mW → 200mW)                                              |  |  |  |
|       |            | - VDD supplies internal PLL                                                                                      |  |  |  |
|       |            | - Register 77 recommended to set to 0                                                                            |  |  |  |
|       |            | Removed:                                                                                                         |  |  |  |
|       |            | - Reference errors                                                                                               |  |  |  |

### Disclaimer



Page 3 of 62





CMOSIS reserves the right to change the product, specification and other information contained in this document without notice. Although CMOSIS does its best efforts to provide correct information, this is not warranted.



## **Table of Contents**

| 1 | intro | oduction                                                                         | /  |
|---|-------|----------------------------------------------------------------------------------|----|
|   | 1.1   | Overview                                                                         | 7  |
|   | 1.2   | Features                                                                         | 7  |
|   | 1.3   | Specifications                                                                   | 7  |
|   | 1.4   | Connection diagram                                                               | 8  |
| 2 | Sens  | sor architecture                                                                 | 9  |
|   | 2.1   | Pixel array                                                                      | 9  |
|   | 2.2   | Analog front end                                                                 | 10 |
|   | 2.3   | LVDS block                                                                       | 10 |
|   | 2.4   | Sequencer                                                                        | 10 |
|   | 2.5   | SPI interface                                                                    | 10 |
|   | 2.6   | Temperature sensor                                                               | 10 |
| 3 | Driv  | ing the CMV4000                                                                  | 12 |
|   | 3.1   | Supply settings                                                                  | 12 |
|   | 3.2   | Biasing                                                                          | 12 |
|   | 3.3   | Digital input pins                                                               | 12 |
|   | 3.4   | electrical I/O specifications                                                    | 13 |
|   |       | 3.4.1 Digital I/O CMOS/TTL DC specifications (see pin list for specific pins)    | 13 |
|   |       | 3.4.2 TIA/EIA-644A LVDS driver specifications (OUTx_N/P, OUTCLK_N/P, OUTCTR_N/P) |    |
|   |       | 3.4.3 TIA/EIA-644A LVDS receiver specifications (LVDS_CLK_N/P)                   | 14 |
|   | 3.5   | Input clock                                                                      | 14 |
|   | 3.6   | Frame rate calculation                                                           | 15 |
|   | 3.7   | Start-up sequence                                                                | 16 |
|   | 3.8   | Reset sequence                                                                   | 17 |
|   | 3.9   | SPI programming                                                                  | 17 |
|   |       | 3.9.1 SPI write                                                                  |    |
|   |       | 3.9.2 SPI read                                                                   | 18 |
|   | 3.10  | Requesting a frame                                                               |    |
|   |       | 3.10.1 Internal exposure control                                                 |    |
|   |       | 3.10.2 External exposure time                                                    | 20 |
| 4 | Read  | ding out the sensor                                                              | 21 |
|   | 4.1   | LVDS data outputs                                                                | 21 |
|   | 4.2   | Low-level pixel timing                                                           | 21 |
|   | 4.3   | Readout timing                                                                   | 22 |



|   |      | 4.3.1   | I 10 bit mode                                                 | 22 |
|---|------|---------|---------------------------------------------------------------|----|
|   |      |         | 4.3.1.1 16 Output channels                                    |    |
|   |      |         | 4.3.1.2 8 output channels                                     |    |
|   |      |         | 4.3.1.3 4 output channels                                     |    |
|   |      |         | 4.3.1.4 2 output channels                                     |    |
|   |      | 4.3.2   |                                                               |    |
|   |      |         | 4.3.2.1 4 output channels                                     |    |
|   |      |         | 4.3.2.2 2 output channels                                     |    |
|   | 4.4  | Pixel ı | l remapping                                                   |    |
|   |      | 4.4.1   |                                                               |    |
|   |      | 4.4.2   |                                                               |    |
|   |      | 4.4.3   | 3 4 outputs                                                   | 24 |
|   |      | 4.4.4   | 1 2 outputs                                                   | 25 |
|   |      | 4.4.5   | 5 Overview                                                    | 25 |
|   | 4.5  | Contr   | trol channel                                                  | 25 |
|   |      | 4.5.1   | L DVAL, LVAL, FVAL                                            | 26 |
|   | 16   | Traini  | ning data                                                     | 27 |
|   |      |         |                                                               |    |
| 5 | Ima  | ge sens | nsor programming                                              | 28 |
|   | 5.1  | Expos   | osure modes                                                   | 28 |
|   | 5.2  | High (  | n dynamic range modes                                         | 28 |
|   |      | 5.2.1   | L Interleaved read-out                                        | 28 |
|   |      | 5.2.2   | 2 Piecewise linear response                                   | 30 |
|   |      |         | 5.2.2.1 Piecewise linear response with internal exposure mode | 31 |
|   |      |         | 5.2.2.2 piecewise linear response with external exposure mode | 31 |
|   |      | 5.2.3   | 3 Multi-frame read-out                                        | 32 |
|   | 5.3  | Wind    | dowing                                                        | 33 |
|   |      |         | L Single window                                               | 33 |
|   |      | 5.3.2   |                                                               |    |
|   | 5.4  |         | ge flipping                                                   |    |
|   |      | _       |                                                               |    |
|   | 5.5  | Image   | ge subsampling                                                |    |
|   |      | 5.5.1   | , , , , , , , , , , , , , , , , , , ,                         |    |
|   |      | 5.5.2   | 2 advanced subsampling                                        | 37 |
|   | 5.6  | Numb    | nber of frames                                                | 38 |
|   | 5.7  | outpu   | out mode                                                      | 38 |
|   | 5.8  | Traini  | ning pattern                                                  | 38 |
|   |      |         |                                                               |    |
|   | 5.9  |         | rnal PLL                                                      |    |
|   |      | 5.9.1   |                                                               |    |
|   |      | 5.9.2   |                                                               |    |
|   | 5.10 | 10-bit  | oit or 12-bit mode                                            | 39 |
|   | 5.11 | Powe    | ver control                                                   | 39 |



|    | 5.12 | 2 Offset and gain                                  | 40   |
|----|------|----------------------------------------------------|------|
|    |      | 5.12.1 Offset                                      | 40   |
|    |      | 5.12.2 Gain                                        | 40   |
|    | 5.13 | 3 Black reference columns                          | 41   |
|    | 5.14 | 4 Horizontal line effect during exposure start     | 41   |
|    | 5.15 | 5 Recommended register settings                    | 42   |
|    |      | 5.15.1 Adjusting registers for optimal performance | 43   |
| 6  | Reg  | ister overview                                     | 44   |
| 7  | Me   | chanical specifications                            | 47   |
|    | 7.1  | Package drawing                                    | 47   |
|    | 7.2  | Assembly drawing                                   | 48   |
|    |      | Cover glass                                        |      |
|    |      | Color filters                                      |      |
| 8  | Tvn  | ical response                                      | . 51 |
|    |      |                                                    |      |
| 9  | -    | ctral response                                     |      |
|    |      | 5μm epi devices                                    |      |
|    |      | 12μm epi devices                                   |      |
| 10 | Pinr | ning                                               | 53   |
|    | 10.1 | 1 Pin List                                         | 53   |
|    | 10.2 | 2 Pin Layout                                       | 54   |
| 11 | Spe  | cification overview                                | 56   |
| 12 | Ord  | lering info                                        | 58   |
| 13 | Han  | ndling and soldering procedure                     | 59   |
|    | 13.1 | 1 Soldering                                        | 59   |
|    |      | 13.1.1 Manual Soldering                            |      |
|    |      | 13.1.2 Wave soldering                              | 59   |
|    |      | 13.1.3 Reflow soldering                            |      |
|    |      | 13.1.4 Soldering Recommendations                   | 60   |
|    | 13.2 | 2 Handling image sensors                           |      |
|    |      | 13.2.1 ESD                                         |      |
|    |      | 13.2.2 Glass cleaning                              |      |
|    | _    |                                                    |      |
|    |      | luation kit                                        |      |
| 15 | Add  | ditional Information                               | 62   |



#### 1 Introduction

#### 1.1 OVERVIEW

The CMV4000 is a high speed CMOS image sensor with 2048 by 2048 pixels (1 optical inch) developed for machine vision applications. The image array consists of 5.5µm x 5.5µm pipelined global shutter pixels which allow exposure during read out, while performing CDS operation. The image sensor has sixteen 10- or 12-bit digital LVDS outputs (serial). The image sensor also integrates a programmable gain amplifier and offset regulation. Each channel runs at 480 Mbps maximum which results in 180 fps frame rate at full resolution. Higher frame rates can be achieved in row-windowing mode or row-subsampling mode. These modes are all programmable using the SPI interface. All internal exposure and read out timings are generated by a programmable on-board sequencer. External triggering and exposure programming is also possible. Extended optical dynamic range can be achieved by multiple integrated high dynamic range modes.

#### 1.2 FFATURES

- 2048 \* 2048 active pixels on a 5.5μm pitch
- frame rate 180 Frames/sec
- row windowing capability
- X-Y mirroring function
- Master clocks: 5-48MHz and 50-480MHz (LVDS)
- 16 LVDS-outputs @480MHz multiplexable to 8, 4 and 2 at reduced frame rate
- LVDS control line with frame and line information
- LVDS DDR output clock to sample data on the receiving end
- 10 bit ADC output at maximum frame rate, 12 bit ADC at reduced frame rate
- Multiple High Dynamic Range modes supported
- On chip temperature sensor
- On chip timing generation
- SPI-control
- Ceramic μPGA package (95 pins)
- 3.3V signaling
- Available in panchromatic and Bayer (RGB)

#### 1.3 Specifications

- Full well charge: 13.5Ke
- Sensitivity: 5.56 V/lux.s (with microlenses @ 550nm)
- Dark noise: 13e RMS
- Conversion factor: 0.075LSB/e<sup>-</sup> (10 bit mode) at unity gain
- Dynamic range: 60 dB
- Extended dynamic range: Piecewise linear response or interleaved read-out
- Parasitic light sensitivity: 1/50 000
- Dark current: 125 e/s (@ 25C die temp)
- Fixed pattern noise: <1 LSB (10 bit mode, <0.1% of full swing, standard deviation on full image)</li>
- Power consumption: 650mW



### 1.4 CONNECTION DIAGRAM



Figure 1: Connection diagram for the CMV4000 image sensor

Please look at the pin list for a detailed description of all pins and their proper connections. Some optional pins are not displayed on the figure above. The exact pin numbers can be found in the pin list and on the package drawing.



### 2 Sensor architecture



Figure 2: Sensor block diagram

Figure 2 shows the image sensor architecture. The internal sequencer generates the necessary signals for image acquisition. The image is stored in the pixel (global shutter) and is then read out sequentially, row-by-row. On the pixel output, an analog gain of x1, x1.2, x1.4 and x1.6 is possible. The pixel values then passes to a column ADC cell, in which ADC conversion is performed. The digital signals are then read out over multiple LVDS channels. Each LVDS channel reads out 128 adjacent columns of the array. In the Y-direction, rows of interest are selected through a row-decoder which allows a flexible windowing. Control registers are foreseen for the programming of the sensor. These register parameters are uploaded via a four-wire SPI interface. A temperature sensor which can be read out over the SPI interface is also included.

#### 2.1 PIXEL ARRAY

The pixel array consists of 2048 x 2048 square global shutter pixels with a pitch of  $5.5\mu m$  ( $5.5\mu m$  x  $5.5\mu m$ ). This results in an optical area of close to 1 optical inch (16mm). This means that off-the-shelve C-mount lenses can be used.



The pixels are designed to achieve maximum sensitivity with low noise and low PLS specifications. Micro lenses are placed on top of the pixels for improved fill factor and quantum efficiency (>50%).

#### 2.2 ANALOG FRONT END

The analog front end consists of 2 major parts, a column amplifier block and a column ADC block.

The column amplifier prepares the pixel signal for the column ADC and applies analog gain if desired (programmable using the SPI interface). The column ADC converts the analog pixel value to a 10 or 12 bit value. A digital offset can also be applied to the output of the column ADC's. All gain and offset settings can be programmed using the SPI interface.

#### 2.3 LVDS BLOCK

The LVDS block converts the digital data coming from the column ADC into standard serial LVDS data running at maximum 480Mbps. The sensor has 18 LVDS output pairs:

- 16 Data channels
- 1 Control channel
- 1 Clock channel

The 16 data channels are used to transfer 10-bit or 12-bit data words from sensor to receiver. The output clock channel transports a DDR clock, synchronous to the data on the other LVDS channels. This clock can be used at the receiving end to sample the data. The data on the control channel contains status information on the validity of the data on the data channels, among other useful sensor status information. Details on the LVDS timing and format can be found in chapter 4 of this document.

LVDS requires parallel termination at the receiver side (if used). So between LVDS\_CLK\_P (pin D1) and LVDS\_CLK\_N (pin D2) should be an external  $100\Omega$  resistor. Also all the LVDS outputs should all be externally terminated at the receiver side. See the TIA/EIA-644A standard for details.

#### 2.4 SEQUENCER

The on-chip sequencer will generate all required control signals to operate the sensor from only a few external control clocks. This sequencer can be activated and programmed through the SPI interface. A detailed description of the SPI registers and sensor (sequencer) programming can be found in chapter 5 of this document.

#### 2.5 SPLINTERFACE

The SPI interface is used to load the sequencer registers with data. The data in these registers is used by the sequencer while driving and reading out the image sensor. Features like windowing, subsampling, gain and offset are programmed using this interface. The data in the on-chip registers can also be read back for test and debug of the surrounding system. Chapter 5 contains more details on register programming and SPI timing.

#### 2.6 TEMPERATURE SENSOR

A 16-bit digital temperature sensor is included in the image sensor and can be controlled by the SPI-interface. The on-chip temperature can be obtained by reading out the registers with address 126 and 127 (in burst mode, see chapter 3.9.2 for more details on this mode).

A calibration of the temperature sensor is needed for absolute temperature measurements per device because the offset differs from device to device. The temperature sensor requires a running input clock (CLK\_IN), the other functions of the image sensor can be operational or in standby mode. The output value of the sensor is dependent on the input clock. A typical temperature sensor output vs. temperature curve at 40MHz can be found below. The die



temperature will be about 10°C~15°C higher than ambient temperature. The ceramic package has about the same temperature as the die.

The typical (offset) value of the temperature sensor at 0°C would be:  $1000 * \frac{f \, [MHz]}{40} \, DN$ . This offset can differ per device. A typical slope would be around  $0.3 * \frac{40}{f \, [MHz]} \, ^{\circ}C/DN$ .

For example, for the calibration of a sensor you're reading out a temperature register value of 1066 at 35°C die temperature and an input frequency of 40MHz. If later you read out the temperature register value and it is 1184. You can calculate the ambient temperature back from that.

Ambient temperature = [(1184-1066)\*0.3\*40/40Mhz] + 35°C = 70.4°C die temperature.

Or vice versa, if you want to know the temperature register value for a die temperature of -10°C at 40MHz:

Register value =  $(-10^{\circ}\text{C} - 35^{\circ}\text{C}) * 40\text{MHz}/40 * (1/0.3) + 1066 = 916 DN$ 

If you want a more accurate calibration you can calibrate the sensor at multiple temperatures, so you will have the exact value of the slope also. For most devices this should be around  $0.29 \sim 0.31$ .



Figure 3: Typical output of the temperature sensor of the CMV4000



Figure 4: Location of the temperature sensor



#### 3 Driving the CMV4000

#### 3.1 SUPPLY SETTINGS

The CMV4000 image sensor has the following supply settings:

| Supply name | Usage                       | Typical value | Range     | DC Power nom | DC Current nom | AC peak current |
|-------------|-----------------------------|---------------|-----------|--------------|----------------|-----------------|
| VDD20       | LVDS, ADC, PLL              | 2.0V          | 1.6V-2.2V | 400mW        | 200mA          | 150mA           |
| VDD33       | Dig. I\O, PGA,<br>SPI, ADC  | 3.3V          | 3V-3.6V   | 200mW        | 60mA           | 40mA            |
| VDDpix      | Pixel array<br>power supply | 3.0V          | 2.3V-3.6V | 3mW          | 1mA            | 1A              |
| Vres_h      | Pixel reset pulse           | 3.3V          | 3.0V-3.6V | 3mW          | 1mA            | 15mA            |

See pin list for exact pin numbers for every supply.

Analog and digital ground can be tied together.

All variations on the VDD33 and VDDpix can contribute to variations (noise) on the analog pixel signal, which is seen as noise in the image. During the camera design precautions have to be taken to supply the sensor with very stable supply voltages to avoid this additional noise.

Because of the AC peak currents, decoupling is advised. Place large decoupling capacitors directly at the output of the voltage regulator to filter low noise and improve peak current supply. We advise  $1x\ 330\mu F$  electrolytic,  $1x\ 33\mu F$  tantalum and a  $10\mu F$  ceramic capacitor per supply, directly at the output of the regulator.

Place small decoupling capacitors as close as possible to the sensor between supply pins and ground. We advise  $1x 4.7\mu F$  and 1x 100n F ceramic capacitor per power supply pin (see pin list) and  $1x 100\mu F$  ceramic capacitor per power supply plane (VDD20, VDDpix, VDD33). Vres h doesn't need a  $100\mu F$  capacitor.

#### 3.2 BIASING

For optimal performance, some pins need to be decoupled to ground or to VDD. Please refer to the pin list for a detailed description for every pin and the appropriate decoupling if applicable.

#### 3.3 DIGITAL INPUT PINS

The table below gives an overview of the external pins used to drive the sensor. The digital signals are sampled on the rising edge of the CLK\_IN, therefor the length of the signal applied to an input should be at least 1 CLK\_IN period to assure it has been detected. All digital I/O's have a capacitance of 2pF max.

| Pin name     | Description                                       |  |  |  |
|--------------|---------------------------------------------------|--|--|--|
| CLK_IN       | Master input clock, frequency range between 5 and |  |  |  |
|              | 48 MHz                                            |  |  |  |
| LVDS_CLK_N/P | High speed LVDS input clock, frequency range      |  |  |  |
|              | between 50 and 480 MHz. Should not be used if PLL |  |  |  |
|              | is enabled (default).                             |  |  |  |



| Pin name  | Description                                                                                                                                                                                                                                  |  |  |  |  |  |
|-----------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--|--|
| SYS_RES_N | System reset pin, active low signal. Resets the onboard sequencer and must be kept low during start-up. This signal should be at least one period of CLK_IN long to assure detection on the rising edge of CLK_IN.                           |  |  |  |  |  |
| FRAME_REQ | Frame request pin. When a rising edge is detected on this pin the programmed number of frames is captured and sent by the sensor. This signal should be at least one period of CLK_IN long to assure detection on the rising edge of CLK_IN. |  |  |  |  |  |
| SPI_IN    | Data input pin for the SPI interface. The data to program the image sensor is sent over this pin.                                                                                                                                            |  |  |  |  |  |
| SPI_EN    | SPI enable pin. When this pin is high the data should be written/read on the SPI                                                                                                                                                             |  |  |  |  |  |
| SPI_CLK   | SPI clock. This is the clock on which the SPI runs (max 48Mz)                                                                                                                                                                                |  |  |  |  |  |
| T_EXP1    | Input pin which can be used to program the exposure time externally. Optional                                                                                                                                                                |  |  |  |  |  |
| T_EXP2    | Input pin which can be used to program the exposure time externally in interleaved high dynamic range mode. Optional                                                                                                                         |  |  |  |  |  |

## 3.4 ELECTRICAL I/O SPECIFICATIONS

### 3.4.1 DIGITAL I/O CMOS/TTL DC SPECIFICATIONS (SEE PIN LIST FOR SPECIFIC PINS)

| Parameter       | Description      | Conditions            | min | typ | max   | Units |
|-----------------|------------------|-----------------------|-----|-----|-------|-------|
| V <sub>IH</sub> | High level input |                       | 2.0 |     | VDD33 | V     |
|                 | voltage          |                       |     |     |       |       |
| V <sub>IL</sub> | Low level input  |                       | GND |     | 0.8   | V     |
|                 | voltage          |                       |     |     |       |       |
| V <sub>OH</sub> | High level       | VDD=3.3V              | 2.4 |     |       | V     |
|                 | output voltage   | I <sub>OH</sub> =-2mA |     |     |       |       |
| V <sub>OL</sub> | Low level output | VDD=3.3V              |     |     | 0.4   | V     |
|                 | voltage          | I <sub>OL</sub> =2mA  |     |     |       |       |

### 3.4.2 TIA/EIA-644A LVDS DRIVER SPECIFICATIONS (OUTx\_N/P, OUTCLK\_N/P, OUTCTR\_N/P)

| Parameter           | Description             | Conditions                                | min   | typ  | max   | Units |
|---------------------|-------------------------|-------------------------------------------|-------|------|-------|-------|
| $V_{OD}$            | Differential            | Steady State, RL                          | 247   | 350  | 454   | mV    |
|                     | output voltage          | = 100Ω                                    |       |      |       |       |
| $\Delta V_{OD}$     | Difference in           | Steady State, RL                          |       |      | 50    | mV    |
|                     | V <sub>OD</sub> between | = 100Ω                                    |       |      |       |       |
|                     | complementary           |                                           |       |      |       |       |
|                     | output states           |                                           |       |      |       |       |
| V <sub>oc</sub>     | Common mode             | Steady State, RL                          | 1.125 | 1.25 | 1.375 | V     |
|                     | voltage                 | = 100Ω                                    |       |      |       |       |
| $\Delta V_{OC}$     | Difference in           | Steady State, RL                          |       |      | 50    | mV    |
|                     | V <sub>oc</sub> between | = 100Ω                                    |       |      |       |       |
|                     | complementary           |                                           |       |      |       |       |
|                     | output states           |                                           |       |      |       |       |
| I <sub>OS,GND</sub> | Output short            | V <sub>OUTP</sub> =V <sub>OUTN</sub> =GND |       |      | 24    | mA    |
|                     | circuit current         |                                           |       |      |       |       |
|                     | to ground               |                                           |       |      |       |       |
| I <sub>OS,PN</sub>  | Output short            | V <sub>OUTP</sub> =V <sub>OUTN</sub>      |       |      | 12    | mA    |
|                     | circuit current         |                                           |       |      |       |       |



#### CMV4000 Datasheet

#### 3.4.3 TIA/EIA-644A LVDS receiver specifications (LVDS CLK N/P)

| Parameter              | Description   | Conditions                       | min | typ | max | Units |
|------------------------|---------------|----------------------------------|-----|-----|-----|-------|
| $V_{ID}$               | Differential  | Steady state                     | 100 | 350 | 600 | mV    |
|                        | input voltage |                                  |     |     |     |       |
| V <sub>IC</sub>        | Receiver      | Steady state                     | 0.0 |     | 2.4 | V     |
|                        | input range   |                                  |     |     |     |       |
| I <sub>ID</sub>        | Receiver      | V <sub>INP INN</sub> =1.2V±50mV, |     |     | 20  | μΑ    |
|                        | input current | 0≤ V <sub>INP INN</sub> ≤2.4V    |     |     |     |       |
| $\Delta I_{\text{ID}}$ | Receiver      | $ I_{INP} - I_{INN} $            |     |     | 6   | μΑ    |
|                        | input current |                                  |     |     |     |       |
|                        | difference    |                                  |     |     |     |       |

#### 3.5 INPUT CLOCK

The input clock (CLK\_IN) defines the output data rate of the CMV4000. The master clock (CLK\_IN) is 10 or 12 times slower than the output data rate, depending on the programmed bit mode setting. The maximum data rate of the output is 480Mbps which results in CLK IN of 48MHz in 10-bit mode and 40MHz in 12-bit mode. The minimum frequency for CLK\_IN is 5MHz. Any frequency between the minimum and maximum can be applied by the user and will result in a corresponding output data rate. The SPI registers with address 114 and 116 must be programmed to the correct frequency range when the CLK\_IN frequency is changed.

| CLK_IN | LVDS_CLK 10bit | LVDS_CLK 12bit |
|--------|----------------|----------------|
| 5 MHz  | 50 MHz         | 60 MHz         |
| 40 MHz | 400 MHz        | 480 MHz        |
| 48 MHz | 480 MHz        | n/a            |

The rising edge LVDS input clock (if used) can only have a maximum delay of 1.00ns with respect to the rising edge of the master clock input to assure proper working of the sensor. This value of 1.00ns is the same for every frequency used.



Figure 5: LVDS clock delay versus master clock

#### 3.6 Frame rate calculation

The frame rate of the CMV4000 is defined by 2 main factors.

- 1. Exposure time
- 2. Read out time

For ease of use we will assume that the exposure time is no longer than the read out time. By assuming this the frame rate is completely defined by the read out time (because the exposure time happens in parallel with the read-out time). The read-out time (and thus the frame rate) is defined by:

1. Output clock speed: max 480Mbps

ADC mode: 10 or 12 bit
 Number of lines read-out

4. Number of LVDS outputs used: max 16 outputs

This means that if any of the parameters above is changed, it will have an impact on the frame rate of the CMV4000. In normal operation (16 outputs @ 480Mbps, 10 bit and full resolution) this will result in 180 fps.

Total readout time is composed of two parts: FOT (frame overhead time) + image readout time

$$FOT = \left( [register 73] + \left( 2 * \frac{16}{\#outputs \ used} \right) \right) * 129 * master \ clock \ period$$

==> The default value of register 73 for the CMV4000 is 20. When running the CMV4000 sensor at 48MHz with 16 outputs and default FOT settings this results in: 59.125us

$$Image\ readout\ time = (129*master\ clock\ period* \frac{16}{\#outputs\ used})*nr\_lines$$

==> When running the CMV4000 sensor at 48MHz with 16 outputs and reading 2048 lines this results in: 5.504ms.

This results in a total read-out time of 59.125us + 5.504ms = 5.563125ms ==> 179.75fps.

The table below gives some examples when reading out a limited number of lines in 10 bit mode.

| Number of columns | Number of lines | Frame rate (fps) |
|-------------------|-----------------|------------------|
| 2048              | 2048            | 180              |
| 2048              | 1024            | 356              |
| 2048              | 70              | 4044             |



Figure 6: Frame period

When the exposure time is greater than the read-out time, the frame rate is mostly defined by the exposure time itself (because the exposure time would be much longer than the FOT).

#### 3.7 START-UP SEQUENCE

The following sequence should be followed when the CMV4000 is started up in default output mode (480Mbps, 10bit resolution). There is no specific startup sequence for the power supplies needed.



Figure 7: Start-up sequence for 480Mbps @ 10-bit

The master clock (48MHz in for 480Mbps in 10-bit mode) should only start after the rise time of the supplies. The external reset pin should be released at least  $1\mu s$  after the supplies have become stable. The first frame can be requested  $1\mu s$  after the reset pin has been released. An optional SPI upload (to program the sequencer) is possible  $1\mu s$  after the reset pin has been released. In this case the Frame\_REQ pulse must be postponed until after the SPI upload has been completed.

When the CMV4000 will be used in 12-bit mode or at a lower speed than 480mbps, an SPI upload is necessary to program the sensor. In this case the start-up sequence looks like the diagram below. A PLL lock-time of 1ms should be considered after uploading the register settings and before sending the FRAME\_REQ pulse.



Figure 8: Start-up sequence for 12-bit mode

The following SPI registers should be uploaded in this mode:

- 1. PLL settings (address 114 and 116): set to correct PLL range
- 2. Bit mode (address 111, 112, 117): set to desired bit mode

#### 3.8 RESET SEQUENCE

If a sensor reset is necessary while the sensor is running the following sequence should be followed.



Figure 9: Reset sequence

The on-board sequencer will be reset and all programming registers will return to their default start-up values when a falling edge is detected on the SYS\_RES\_N pin. After the reset there is a minimum time of 1ms needed before a FRAME\_REQ pulse can be sent.

When a switch from 10-bit to 12-bit mode (or vice versa) is necessary, the following sequence should be followed.



Figure 10: Reset sequence when changing bit mode

The following SPI registers (ADC settings) should be uploaded in this mode:

- 1. PLL setting (address 114 and 116): set to correct PLL range
- 2. Bit mode (address 111, 112 and 117): set to desired bit mode

### 3.9 SPI PROGRAMMING

Programming the sensor is done by writing the appropriate values to the on-board registers. These registers can be written over a simple serial interface (SPI). The details of the timing and data format are described below. The data written to the programming registers can also be read out over this same SPI interface.

#### 3.9.1 SPI WRITE

The timing to write data over the SPI interface can be found below.



Figure 11: SPI write timing

The data is sampled by the CMV4000 on the rising edge of the SPI\_CLK. The SPI\_CLK has a maximum frequency of 48MHz. The SPI\_EN signal has to be high for half a clock period before the first data bit is sampled. SPI\_EN has to remain high for 1 clock period after the last data bit is sampled.



One write action contains 16 data bits:

- One control bit: First bit to be sent, indicates whether a read ('0') or write ('1') will occur on the SPI interface.
- 7 address bits: These bits form the address of the programming register that needs to be written. The address is sent MSB first.
- 8 data bits: These bits form the actual data that will be written in the register selected with the address bits. The data is written MSB first.

When several sensor registers need to be written, the timing above can be repeated with SPI\_EN remaining high all the time. See the figure below for an example of 2 registers being written in burst.



Figure 12: SPI write timing for 2 registers in burst

All registers should be updated during IDLE time. The sensor is not IDLE during a frame burst (between start of integration of first frame and readout of last pixel of last frame).

Registers 35-38, 40-69, 100-103 can be updated during IDLE or FOT. Registers 1-34 and 70-71 can always be updated but it is recommended to update these during IDLE or FOT to minimize image effects. Registers 78-79 can always be updated without disrupting the imaging process.

#### 3.9.2 SPI READ

The timing to read data from the registers over the SPI interface can be found below.



Figure 13: SPI read timing

To indicate a read action over the SPI interface, the control bit on the SPI\_IN pin is made '0'. The address of the register being read out is sent immediately after this control bit (MSB first). After the LSB of the address bits, the data is launched on the SPI\_OUT pin on the falling edge of the SPI\_CLK. This means that the data should be sampled by the receiving system on the rising edge of the SPI\_CLK. The data comes over the SPI\_OUT with MSB first. When reading out the temperature sensor over the SPI, addresses 126 and 127 should de read-out in burst mode (keep SPI\_EN high)

### 3.10 REQUESTING A FRAME

After starting up the sensor (see 3.7), a number of frames can be requested by sending a FRAME\_REQ pulse. The number of frames can be set by programming the appropriate register (addresses 70 and 71). The default number of frames to be grabbed is 1.

In internal-exposure-time mode, the exposure time will start after this FRAME\_REQ pulse. In the external-exposure-time mode, the read-out will start after the FRAME\_REQ pulse. Both modes are explained into detail in the chapters below.



#### 3.10.1 INTERNAL EXPOSURE CONTROL

In this mode, the exposure time is set by programming the appropriate registers (address 42-44) of the CMV4000.

After the high state of the FRAME\_REQ pulse is detected, the exposure time will start immediately. When the exposure time ends (as programmed in the registers), the pixels are being sampled and prepared for read-out. This sequence is called the frame overhead time (FOT). Immediately after the FOT, the frame is read-out automatically. If more than one frame is requested, the exposure of the next frame starts already during the read-out of the previous one. See the diagram below for more details.



Figure 14: request for 2 frames in internal- exposure-time mode



Figure 15: Two requests for 1 frame in internal exposure mode

When the exposure time is shorter than the read-out time, the FOT and read-out of the next frame will start immediately after the read-out of the previous frame. Keep in mind that the next Frame\_req pulse has to occur after the FOT of the current frame. For an exact calculation of the exposure time see chapter 5.1. When a new Frame\_REQ is applied, the exposure of the next frame will be delayed so that the FOT begins right after the read-out time of the current frame.



Figure 16: Request for 2 frames in internal exposure mode with exposure time < read-out time



Figure 17: Two requests for 1 frame in internal exposure mode



#### 3.10.2 EXTERNAL EXPOSURE TIME

The exposure time can also be programmed externally by using the T\_EXP1 input pin. This mode needs to be enabled by setting the appropriate register (address 41). In this case, the exposure starts when a high state is detected on the T\_EXP1 pin. When a high state is detected on the FRAME\_REQ input, the exposure time stops and the read-out will start automatically. A new exposure can start by sending a pulse to the T\_EXP1 pin during or after the read-out of the previous frame. The minimum time between T\_EXP and Frame\_REQ is 1 master clock cycle, the minimum time between FRAME\_REQ and T\_EXP1 pulse is FOT. For an exact calculation of the exposure time see chapter 5.1.



Figure 18: request for 2 frames using external-exposure-time mode



### 4 READING OUT THE SENSOR

#### 4.1 LVDS DATA OUTPUTS

The CMV4000 has LVDS (low voltage differential signaling) outputs to transport the image data to the surrounding system. Next to 16 data channels, the sensor also has two other LVDS channels for control and synchronization of the image data. In total, the sensor has 18 LVDS output pairs (2 pins for each LVDS channel):

- 16 Data channels
- 1 Control channel
- 1 Clock channel

This means that a total of 36 pins of the CMV4000 are used for the LVDS outputs (32 for data + 2 for LVDS clock + 2 for control channel). See the pin list for the exact pin numbers of the LVDS outputs.

The 16 data channels are used to transfer the 10-bit or 12-bit pixel data from the sensor to the receiver in the surrounding system.

The output clock channel transports a clock, synchronous to the data on the other LVDS channels. This clock can be used at the receiving end to sample the data. This clock is a DDR clock which means that the frequency will be half of the output data rate. When 480Mbps output data rate is used, the LVDS output clock will be 240MHz.

The data on the control channel contains status information on the validity of the data on the data channels. Information on the control channel is grouped in 10-bit or 12-bit words that are transferred synchronous to the 16 data channels.

### 4.2 LOW-LEVEL PIXEL TIMING

The figures below show the timing for transfer of 10-bit and 12-bit pixel data over one LVDS output. To make the timing more clear, the figures show only the p-channel of each LVDS pair. The data is transferred LSB first, with the transfer of bit D[0] during the high phase of the DDR output clock.



Figure 19: 10-bit pixel data on an LVDS channel

The time 'T1' in the diagram above is  $1/10^{th}$  of the period of the input clock (CLK\_IN) of the CMV4000. When a frequency of 48MHz is used for CLK\_IN (max in 10-bit mode), this results in a 240MHz LVDS\_CLOCK.



Figure 20: 12-bit pixel data on an LVDS channel

The time 'T2' in figure 14 is 1/12<sup>th</sup> of the period of the input clock (CLK\_IN) of the CMV4000. When a frequency of 40MHz is used for CLK\_IN (max in 12-bit mode), this results in a 240MHz LVDS\_CLOCK.

Reference: CMV4000-datasheet-v3.2

#### 4.3 READOUT TIMING

The readout of image data is grouped in bursts of 128 pixels per channel. Each pixel is either 10 or 12 bits of data (see 4.2). One complete pixel period equals one period of the master clock input. For details on pixel remapping and pixel vs. channel location please see chapter 4.4 of this document. An overhead time exists between two bursts of 128 pixels. This overhead time has the same length of one pixel read-out (i.e. the length of 10 or 12 bits at the selected data rate or one master clock period).

#### 4.3.1 10 BIT MODE

In this section, the readout timing for the default 10 bit mode is explained. In this mode the maximum frame rate of 180 fps can be reached.

#### 4.3.1.1 16 OUTPUT CHANNELS

By default, all 16 data output channels are used to transmit the image data. This means that an entire row of image data is transferred in one slot of 128 pixel periods (16\*128 = 2048). Next figure shows the timing for one LVDS channel.



Figure 21: Output timing in default 16 channel mode

Only when 10 bit mode and 16 data outputs, running at 480Mbps, are used, the frame rate of 180fps can be achieved (default).

#### 4.3.1.2 8 OUTPUT CHANNELS

The CMV4000 has the possibility to use only 8 LVDS output channels. This setting can be programmed in the register with address 72 (see 5.7). In such multiplexed output mode, the readout of one row takes (2\*128) + (2\*1) master clock periods. Next figure shows the timing for one LVDS channel.



Figure 22: Output timing in 8 channel mode

In this 8 channel mode, the frame rate is reduced with factor of 2 compared to 16 channel mode.

#### 4.3.1.3 4 OUTPUT CHANNELS

The CMV4000 has the possibility to use only 4 LVDS output channels. This setting can be programmed in the register with address 72 (see 5.7). In such multiplexed output mode, the readout of one row takes (4\*128) + (4\*1) master clock periods. Next figure shows the timing for one LVDS channel.



Figure 23: Output timing in 4 channel mode

In this 4 channel mode, the frame rate is reduced with factor 4 compared to 16 channel mode.

#### 4.3.1.4 2 OUTPUT CHANNELS

The CMV4000 has the possibility to use only 2 LVDS output channels. This setting can be programmed in the register with address 72 (see 5.7). In such multiplexed output mode, the readout of one row takes (8\*128) + (8\*1) master clock periods. Next figure shows the timing for one LVDS channel.





Figure 24: Output timing in 2 channel mode

In this 2 channel mode, the frame rate is reduced with factor of 8 compared to 16 channel mode.

#### 4.3.2 12 BIT MODE

In 12 bit mode, the analog-to-digital conversion takes 4x longer to complete. This causes the frame rate to drop to 37.5 fps when 40MHz is used for CLK\_IN. Due to this extra conversion time, the sensor automatically multiplexes to 4 outputs when 12 bit is used.

#### 4.3.2.1 4 OUTPUT CHANNELS

By default, the CMV4000 uses only 4 LVDS output channels in 12 bit mode. This setting can be programmed in the register with address 72 (see 5.7). In such multiplexed output mode, the readout of one row takes (4\*128) + (4\*1) master clock periods. Next figure shows the timing for one LVDS channel.



Figure 25: Output timing in 4 channel mode

#### 4.3.2.2 2 OUTPUT CHANNELS

The CMV4000 has the possibility to use only 2 LVDS output channels. This setting can be programmed in the register with address 72 (see 5.7). In such multiplexed output mode, the readout of one row takes (8\*128) + (8\*1) master clock periods. Next figure shows the timing for one LVDS channel.



Figure 26: Output timing in 2 channel mode

In this 2 channel mode, the frame rate is reduced with factor of 2 compared to 4 channel mode.

#### 4.4 PIXEL REMAPPING

Depending on the number of output channels, the pixels are read out by different channels and come out at a different moment in time. With the details from the next sections, the end user is able to remap the pixel values at the output to their correct image array location.

#### 4.4.1 16 OUTPUTS

The figure below shows the location of the image pixels versus the output channel of the image sensor.

16 bursts of 128 pixels happen in parallel on the data outputs. This means that one complete row is read out in one burst. The amount of rows that will be read out depends on the value in the corresponding register. By default there are 2048 rows being read out.



Figure 27: Pixel remapping for 16 output channels

#### 4.4.2 8 OUTPUTS

When only 8 outputs are used, the pixel data is placed on the outputs as detailed in the figure below. 8 bursts of 128 pixels happen in parallel on the data outputs. This means that one complete row is read out in two bursts. The time needed to read out one row is doubled compared to when 16 outputs are used. Channel 2, 4, 6...16 are not being used in this mode, so they can be turned off by setting the correct bits in the register with addresses 80-82. Turning off these channels will reduce the power consumption of the chip.

The amount of rows that will be read out depends on the value in the corresponding register. By default there are 2048 rows being read out.



Figure 28: Pixel remapping for 8 output channels

#### 4.4.3 4 OUTPUTS

When only 4 outputs are used, the pixel data is placed on the outputs as detailed in the figure below. 4 bursts of 128 pixels happen in parallel on the data outputs. This means that one complete row is read out in four bursts. The time needed to read out one row is 4x longer compared to when 16 outputs are used. Only channel 1, 5, 9 and 13 are being used in this mode, so the remaining channels can be turned off by setting the correct bits in the register with addresses 80-82. Turning off these channels will reduce the power consumption of the chip.

The amount of rows that will be read out depends on the value in the corresponding register. By default there are 2048 rows being read out.



Figure 29: Pixel remapping for 4 output channels

#### 4.4.4 2 OUTPUTS

When only 2 outputs are used, the pixel data is placed on the outputs as detailed in the figure below. 2 bursts of 128 pixels happen in parallel on the data outputs. This means that one complete row is read out in 8 bursts. The time needed to read out one row is 8x longer compared to when 16 outputs are used. Only channel 1 and 9 are being used in this mode, so the remaining channels can be turned off by setting the correct bits in the register with addresses 80-82. Turning off these channels will reduce the power consumption of the chip.

The amount of rows that will be readout depends on the value in the corresponding register. By default there are 2048 rows being read out.



Figure 30: Pixel remapping for 2 output channels

#### 4.4.5 OVERVIEW

All outputs are always used to send data, but if you use less than 16 channels, some channels will have duplicate data. For example if you multiplex to 8 channels, outputs 6, 7 and 8 will have identical data as output 5. Below you see an overview of which channel data is on which output at a certain output mode.

| MUX | OUT  | OUT  | OUT  | OUT  | OUT  | OUT  | OUT  |
|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|------|------|------|------|------|------|------|
| to  | 1   | 2   | 3   | 4   | 5   | 6   | 7   | 8   | 9   | 10   | 11   | 12   | 13   | 14   | 15   | 16   |
| 16  | CH1 | CH2 | CH3 | CH4 | CH5 | CH6 | CH7 | CH8 | CH9 | CH10 | CH11 | CH12 | CH13 | CH14 | CH15 | CH16 |
| 8   | CH1 | CH1 | CH3 | CH3 | CH5 | CH5 | CH7 | CH7 | CH9 | CH9  | CH11 | CH11 | CH13 | CH13 | CH15 | CH15 |
| 4   | CH1 | CH1 | CH1 | CH1 | CH5 | CH5 | CH5 | CH5 | CH9 | CH9  | CH9  | CH9  | CH13 | CH13 | CH13 | CH13 |
| 2   | CH1 | CH9 | CH9  | CH9  | CH9  | CH9  | CH9  | CH9  | CH9  |

### 4.5 CONTROL CHANNEL

The CMV4000 has one LVDS output channel dedicated for the valid data synchronization and timing of the output channels. The end user must use this channel to know when valid image data or training data is available on the data output channels.

The control channel transfers status information in 10-bit or 12-bit word format. Every bit of the word has a specific function. Next table describes the function of the individual bits.

| Bit | Function | Description                                                                |
|-----|----------|----------------------------------------------------------------------------|
| [0] | DVAL     | Indicates valid pixel data on the outputs                                  |
| [1] | LVAL     | Indicates validity of the readout of a row                                 |
| [2] | FVAL     | Indicates the validity of the readout of a frame                           |
| [3] | SLOT     | Indicates the overhead period before 128-pixel bursts (*)                  |
| [4] | ROW      | Indicates the overhead period before the readout of a row (*)              |
| [5] | FOT      | Indicates when the sensor is in FOT (sampling of image data in pixels) (*) |
| [6] | INTE1    | Indicates when pixels of integration block 1 are integrating (*)           |
| [7] | INTE2    | Indicates when pixels of integration block 2 are integrating (*)           |



| Bit  | Function   | Description   |
|------|------------|---------------|
| [8]  | '0'        | Constant zero |
| [9]  | <b>'1'</b> | Constant one  |
| [10] | '0'        | Constant zero |
| [11] | '0'        | Constant zero |

(\*)Note: The status bits are purely informational. These bits are not required to know when the data is valid. The DVAL, LVAL and FVAL signals are sufficient to know when to sample the image data.

INTE1/2 will be low when FOT is high, so the exposure during the small 0.43\*reg73 overlap (see formulas in 5.1), will not be visible in the INTE1/2 bits.

Pins H2 (T\_dig1) and G2 (T\_dig2) can be programmed to map the state of control channel bits [0] (DVAL), [1] (LVAL), [2] (FVAL), [6] (INTE1) or [7] (INTE2) with registers 108 (T\_dig1) and 109 (T\_dig2).

| Register 108/109 Value | T_dig1 | T_dig2 |
|------------------------|--------|--------|
| 0                      | INTE1  | INTE1  |
| 1                      | INTE2  | INTE2  |
| 2                      | DVAL   | DVAL   |
| 3                      | LVAL   | LVAL   |
| 4                      | FVAL   | FVAL   |

#### 4.5.1 DVAL, LVAL, FVAL

The first three bits of the control word must be used to identify valid data and the readout status.

Next figure shows the timing of the DVAL, LVAL and FVAL bits of the control channel with an example of the readout of a frame of 3 rows (default is 2048 rows). This example uses the default mode of 16 outputs in 10 bit mode.



Figure 31: DVAL, LVAL and FVAL timing in 16 output mode

When only 8 outputs are used, the line read-out time is 2x longer. The control channel takes this into account and the timing in this mode looks like the diagram below. The timing extrapolates identically for 4 and 2 outputs.



Figure 32: DVAL, LVAL and FVAL timing in 8 output mode

#### CMV4000 Datasheet



Figure 33: Detailed timings of the Control Channel (8 outputs, 3 lines window)

#### 4.6 TRAINING DATA

To synchronize the receiving side with the LVDS outputs of the CMV4000, a known data pattern can be put on the output channels. This pattern can be used to "train" the LVDS receiver of the surrounding system to achieve correct word alignment of the image data. Such a training pattern is put on all 16 data channel outputs when there is no valid image data to be sent (so, also in between bursts of 128 pixels). The training pattern is a 10-bit or 12-bit data word that replaces the pixel data. The sensor has a 12-bit sequencer register (address 78-79) that can be loaded through the SPI to change the contents of the 12-bit training pattern.

The control channel does not send a training pattern, because it is used to send control information at all time. Word alignment can be done on this channel when the sensor is idle (not exposing or sending image data). In this case all bits of the control word are zero, except for bit [9] (= 0010 0000 0000 or 512 decimal).

The figure below shows the location of the training pattern (TP) on the data channels and control channels when the sensor is in idle mode and when a frame of 3 rows is read-out. The default mode of 16 outputs is selected.



Figure 34: Training pattern location in the data and control channels.



### 5 IMAGE SENSOR PROGRAMMING

This section explains how the CMV4000 can be programmed using the on-board sequencer registers.

#### 5.1 EXPOSURE MODES

The exposure time can be programmed in two ways, externally or internally. Externally, the exposure time is defined as the time between the rising edge of T\_EXP1 and the rising edge of FRAME\_REQ (see chapter 3.10.2 for more details). Internally, the exposure time is set by uploading the desired value to the corresponding sequencer register.

The table below gives an overview of the registers involved in the exposure mode.

|               |                  | Exposure      | time settings                                             |
|---------------|------------------|---------------|-----------------------------------------------------------|
| Register name | Register address | Default value | Description of the value                                  |
| Exp_ext       | 41 bit[0]        | 0             | 0: Exposure time is defined by the value uploaded in the  |
|               |                  |               | sequencer register (42-44)                                |
|               |                  |               | 1: Exposure time is defined by the pulses applied to the  |
|               |                  |               | T_EXP1 and FRAME_REQ pins.                                |
| Exp_time      | 42-44            | 2048          | <u>If Exp_ext = 0:</u>                                    |
|               |                  |               | The value in this register defines the exposure time      |
|               |                  |               | according to the following formula:                       |
|               |                  |               |                                                           |
|               |                  |               | $129 * clk\_per(0.43 * reg73 + Exp\_time)$                |
|               |                  |               |                                                           |
|               |                  |               | Where clk_per is the period of the master input clock and |
|               |                  |               | reg73 is the value in register 73.                        |
|               |                  |               |                                                           |
|               |                  |               | <u>If Exp_ext = 1:</u>                                    |
|               |                  |               | The exposure time is:                                     |
|               |                  |               |                                                           |
|               |                  |               | 129 * clk_per(0.43 * reg73) + external exposure time      |
|               |                  |               |                                                           |
|               |                  |               | Where external exposure time is the time between T_Exp1   |
|               |                  |               | and Frame_REQ.                                            |

To calculate back from actual exposure time to the register value for internal exposure can use the following formula (exposure time and clk\_per should have the same time unit):

$$Exp\_time = \frac{exposure\ time}{129*clk\_per} - 0.43*reg73$$

#### 5.2 HIGH DYNAMIC RANGE MODES

The sensor has different ways to achieve high optical dynamic range in the grabbed image.

- Interleaved read-out: the odd and even rows have a different exposure time
- Piecewise linear response: pixels respond to light with a piecewise linear response curve.
- Multi-frame readout: Different frames are read-out with increasing exposure time

All the HDR modes mentioned above can be used in both the internal and external exposure time mode.

#### 5.2.1 INTERLEAVED READ-OUT

In this HDR mode, the odd and even rows of the image sensors will have a different exposure time. This mode can be enabled by setting the register in the table below.



|         | g         |
|---------|-----------|
| CMV4000 | Datasheet |
|         |           |

| HDR settings – interleaved read-out |                  |               |                                       |  |  |  |
|-------------------------------------|------------------|---------------|---------------------------------------|--|--|--|
| Register name                       | Register address | Default value | Description of the value              |  |  |  |
| Exp_dual                            | 41 bit[1]        | 0             | 0: interleaved exposure mode disabled |  |  |  |
|                                     |                  |               | 1: interleaved exposure mode enabled  |  |  |  |

The surrounding system can combine the image of the odd rows with the image of the even rows which can result in a high dynamic range image. In such an image very bright and very dark objects are made visible without clipping. The table below gives an overview of the registers involved in the interleaved read-out when the internal exposure mode is selected.

|               |                  | HDR settings – i | nterleaved read-out                                                                                                                                                                |
|---------------|------------------|------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Register name | Register address | Default value    | Description of the value                                                                                                                                                           |
| Exp_time      | 42-44            | 2048             | When the Exp_dual register is set to '1', the value in this register defines the exposure time for the even rows according following formula: $129*clk\_per(0.43*reg73+Exp\_time)$ |
|               |                  |                  | Where clk_per is the period of the master input clock.                                                                                                                             |
| Exp_time2     | 56-58            | 2048             | When the Exp_dual register is set to '1', the value in this register defines the exposure time for the odd rows according following formula:                                       |
|               |                  |                  | $129*clk\_per(0.43*reg73+Exp\_time2)$ Where clk_per is the period of the master input clock.                                                                                       |

When the external exposure mode and interleaved read-out are selected, the different exposure times are achieved by using the T\_EXP1 and T\_EXP2 input pins. T\_EXP1 defines the exposure time for the even lines, while T\_EXP2 defines the exposure time for the odd lines. See the figure below for more details.



Figure 35: Interleaved read-out in external exposure mode

When a color sensor is used, the sequencer should be programmed to make sure it takes the Bayer pattern into account when doing interleaved read-out. This can be done by setting the appropriate register to '0'.

| Color/mono    |                  |               |                              |  |  |
|---------------|------------------|---------------|------------------------------|--|--|
| Register name | Register address | Default value | Description of the value     |  |  |
| Color         | 39               | 1             | 0: color sensor is used      |  |  |
|               |                  |               | 1: monochrome sensor is used |  |  |



#### 5.2.2 PIECEWISE LINEAR RESPONSE

The CMV4000 has the possibility to achieve a high optical dynamic range by using a piecewise linear response. This feature will clip illuminated pixels which reach a programmable voltage, while leaving the darker pixels untouched. The clipping level can be adjusted 2 times within one exposure time to achieve a maximum of 3 slopes in the response curve. More details can be found in the figure below.



Figure 36: Piecewise linear response details

In the figure above, the red lines represent a pixel on which a large amount of light is falling. The blue line represents a pixel on which less light is falling. As shown in the figure, the bright pixel is held to a programmable voltage for a programmable time during the exposure time. This happens two times to make sure that at the end of the exposure time the pixel is not saturated. The darker pixel is not influenced and will have a normal response. The Vlow voltages and different exposure times are programmable using the sequencer registers. Using this feature, a response as detailed in the figure below can be achieved. The placement of the knee points on the X-axis is controlled by the Vlow programming, while the slope of the segments is controlled by the programmed exposure times.



Figure 37: Piecewise linear response

#### 5.2.2.1 PIECEWISE LINEAR RESPONSE WITH INTERNAL EXPOSURE MODE

The following registers need to be programmed when a piecewise linear response in internal exposure mode is desired.

|               |                  | HDR settings  | – multiple slope                                                                                                                                                                    |
|---------------|------------------|---------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Register name | Register address | Default value | Description of the value                                                                                                                                                            |
| Exp_time      | 42-44            | 2048          | The value in this register defines the total exposure time according following formula: $129*clk\_per(0.43*reg73+Exp\_time)$ Where clk_per is the period of the master input clock. |
| Nr_slopes     | 54               | 1             | The value in this register defines the number of slopes (min=1, max=3).                                                                                                             |
| Exp_kp1       | 48-50            | 1             | The value in this register defines the exposure time of kneepoint 1. Formula: $129*clk\_per(0.43*reg73+Exp\_kp1)$                                                                   |
|               |                  |               | Where clk_per is the period of the master input clock.                                                                                                                              |
| Exp_kp2       | 51-53            | 1             | The value in this register defines the exposure time of kneepoint 2. Formula: $129*clk\_per(0.43*reg73+Exp\_kp2)$ Where clk\_per is the period of the master input clock.           |
| Vlow3         | 90               | 96            | The value in this register defines the Vlow3 voltage (DAC setting).  Bit [6] = enable  Bit[5:0] = Vlow3 value                                                                       |
| Vlow2         | 89               | 96            | The value in this register defines the Vlow2 voltage (DAC setting).  Bit [6] = enable  Bit[5:0] = Vlow3 value                                                                       |

### 5.2.2.2 PIECEWISE LINEAR RESPONSE WITH EXTERNAL EXPOSURE MODE



When external exposure time is used and a piecewise linear response is desired, the following registers should be programmed.

|               | HDR settings – multiple slope |               |                                                                         |  |  |  |  |
|---------------|-------------------------------|---------------|-------------------------------------------------------------------------|--|--|--|--|
| Register name | Register address              | Default value | Description of the value                                                |  |  |  |  |
| Nr_slopes     | 54                            | 1             | The value in this register defines the number of slopes (min=1, max=3). |  |  |  |  |
| Vlow3         | 90                            | 96            | The value in this register defines the Vlow3 voltage (DAC setting).     |  |  |  |  |
| Vlow2         | 89                            | 96            | The value in this register defines the Vlow2 voltage (DAC setting).     |  |  |  |  |

The timing that needs to be applied in this external exposure mode looks like the one below.



Figure 38: Piecewise linear response with external exposure time mode

Please note, that a combination of the piecewise linear response and interleaved read-out is not possible.

#### 5.2.3 Multi-frame read-out

The sensor has the possibility to read-out multiple frames with increasing exposure time for each frame. The exposure time step and number of frames can be programmed using the appropriate registers. The frames grabbed in this mode, can be combined to create one high dynamic range image. This combination needs to be made by the receiving system.

The following registers should be used when this multi-frame read-out is selected. This mode only works with internal exposure time setting.

| HDR settings – multi-frame read-out |                  |               |                                                                                                   |  |  |  |
|-------------------------------------|------------------|---------------|---------------------------------------------------------------------------------------------------|--|--|--|
| Register name                       | Register address | Default value | Description of the value                                                                          |  |  |  |
| Exp_time                            | 42-44            | 2048          | The value in this register defines the exposure time of the                                       |  |  |  |
|                                     |                  |               | first frame in the sequence. Formula:                                                             |  |  |  |
|                                     |                  |               | $129*clk\_per(0.43*reg73+Exp\_time)$                                                              |  |  |  |
|                                     |                  |               | Where clk_per is the period of the master input clock.                                            |  |  |  |
| Exp_step                            | 45-47            | 0             | The value in this register defines the step size for the                                          |  |  |  |
|                                     |                  |               | increasing exposure times in multi-frame read-out. This                                           |  |  |  |
|                                     |                  |               | value will be added to Exp_time per frame. So the exposure time for the n <sup>th</sup> frame is: |  |  |  |
|                                     |                  |               | $129 * clk\_per(0.43 * ref73 + Exp\_time + (n - 1) * Exp\_step)$                                  |  |  |  |
|                                     |                  |               | Where clk_per is the period of the master input clock and n                                       |  |  |  |
|                                     |                  |               | is the n <sup>th</sup> frame.                                                                     |  |  |  |



| Exp_seq | 55 | 1 | The value in this register defines the number of frames to |
|---------|----|---|------------------------------------------------------------|
|         |    |   | be read-out in multi-frame mode (min = 1, max = 255).      |

#### 5.3 WINDOWING

To limit the amount of data or to increase the frame rate of the sensor, windowing in Y direction is possible. The number of lines and start address can be set by programming the appropriate registers. The CMV4000 has the possibility to read-out multiple (max=8) predefined sub windows in one read-out cycle. The default mode is to read-out one window with the full frame size (2048x2048).

#### 5.3.1 SINGLE WINDOW

When a single window is read out, the start address and size can be uploaded in the corresponding registers. The default start address is 0 and the default size is 2048 (full frame).

| Windowing – single window |                  |               |                                                                                                |
|---------------------------|------------------|---------------|------------------------------------------------------------------------------------------------|
| Register name             | Register address | Default value | Description of the value                                                                       |
| start1                    | 3-4              | 0             | The value in this register defines the start address of the window in Y (min=0, max=2047)      |
| Number_lines              | 1-2              | 2048          | The value in this register defines the number of lines readout by the sensor (min=1, max=2048) |



Figure 39: Single window settings

#### 5.3.2 MULTIPLE WINDOWS

The CMV4000 can read out a maximum of 8 different sub windows in one read-out cycle. The location and length of these sub windows must be programmed in the correct registers. The total number of lines to be read-out (sum of all windows) needs to be specified in the Number\_lines register. The registers which need to be programmed for the multiple windows can be found in the table below.



| Windowing – multiple windows |                  |               |                                                               |
|------------------------------|------------------|---------------|---------------------------------------------------------------|
| Register name                | Register address | Default value | Description of the value                                      |
| Number_lines                 | 1-2              | 2048          | The value in this register defines the total number of lines  |
|                              |                  |               | read-out by the sensor (min=1, max=2048)                      |
| start1                       | 3-4              | 0             | The value in this register defines the start address of the   |
|                              |                  |               | first window in Y (min=0, max=2047)                           |
| Number_lines1                | 19-20            | 0             | The value in this register defines the number of lines of the |
|                              |                  |               | first window (min=1, max=2048)                                |
| start2                       | 5-6              | 0             | The value in this register defines the start address of the   |
|                              |                  |               | second window in Y (min=0, max=2047)                          |
| Number_lines2                | 21-22            | 0             | The value in this register defines the number of lines of the |
|                              |                  |               | second window (min=1, max=2048)                               |
| start3                       | 7-8              | 0             | The value in this register defines the start address of the   |
|                              |                  |               | third window in Y (min=0, max=2047)                           |
| Number_lines3                | 23-24            | 0             | The value in this register defines the number of lines of the |
|                              |                  |               | third window (min=1, max=2048)                                |
| start4                       | 9-10             | 0             | The value in this register defines the start address of the   |
|                              |                  |               | fourth window in Y (min=0, max=2047)                          |
| Number_lines4                | 25-26            | 0             | The value in this register defines the number of lines of the |
|                              |                  |               | fourth window (min=1, max=2048)                               |
| start5                       | 11-12            | 0             | The value in this register defines the start address of the   |
|                              |                  |               | fifth window in Y (min=0, max=2047)                           |
| Number_lines5                | 27-28            | 0             | The value in this register defines the number of lines of the |
|                              |                  |               | fifth window (min=1, max=2048)                                |
| start6                       | 13-14            | 0             | The value in this register defines the start address of the   |
|                              |                  |               | sixth window in Y (min=0, max=2047)                           |
| Number_lines6                | 29-30            | 0             | The value in this register defines the number of lines of the |
|                              |                  |               | sixth window (min=1, max=2048)                                |
| start7                       | 15-16            | 0             | The value in this register defines the start address of the   |
|                              |                  |               | seventh window in Y (min=0, max=2047)                         |
| Number_lines7                | 31-32            | 0             | The value in this register defines the number of lines of the |
|                              |                  |               | seventh window (min=1, max=2048)                              |
| start8                       | 17-18            | 0             | The value in this register defines the start address of the   |
|                              |                  |               | eighth window in Y (min=0, max=2047)                          |
| Number_lines8                | 33-34            | 0             | The value in this register defines the number of lines of the |
|                              |                  |               | eighth window (min=1, max=2048)                               |

Note: The default values will result in one window with 2048 lines to be read-out



Figure 40: Example of 4 multiple frames read-out

#### 5.4 IMAGE FLIPPING

The image coming out of the image sensor can be flipped in X (per channel) and/or Y direction. When flipping in Y is enabled, the bottom left pixel is read out first instead of the top left. When flipping in X is enabled, only the pixels within a channel are mirrored, not the channels themselves.





Figure 41: Image flipping

The following registers are involved in image flipping:

| Image flipping |                  |               |                              |
|----------------|------------------|---------------|------------------------------|
| Register name  | Register address | Default value | Description of the value     |
| Image_flipping | 40               | 0             | 0: No image flipping         |
|                |                  |               | 1: Image flipping in X       |
|                |                  |               | 2: Image flipping in Y       |
|                |                  |               | 3: Image flipping in X and Y |

### 5.5 IMAGE SUBSAMPLING

To maintain the same field of view but reduce the amount of data coming out of the sensor, a subsampling mode is implemented on the chip. Different subsampling schemes can be programmed by setting the appropriate registers. These subsampling schemes can take into account whether a color or monochrome sensor is used to preserve the Bayer pattern information. The registers involved in subsampling are detailed below. A distinction is made between a simple and advanced mode (can be used for color devices). Subsampling can be enabled in every windowing mode.

#### 5.5.1 SIMPLE SUBSAMPLING

| Image subsampling - simple |                  |               |                                                                                                       |
|----------------------------|------------------|---------------|-------------------------------------------------------------------------------------------------------|
| Register name              | Register address | Default value | Description of the value                                                                              |
| Number_lines               | 1-2              | 2048          | The value in this register defines the total number of lines read-out by the sensor (min=1, max=2048) |
| Sub_s                      | 35-36            | 0             | Number of rows to skip (min=0, max=2046)                                                              |
| Sub_a                      | 37-38            | 0             | Identical to Sub_s                                                                                    |

The figures below give two subsampling examples (skip 4x and skip 1x).



Figure 42: Subsampling examples (skip 4x and skip 1x)

### 5.5.2 ADVANCED SUBSAMPLING

When a color sensor is used, the subsampling scheme should take into account that a Bayer color filter is applied on the sensor. This Bayer pattern should be preserved when subsampling is used. This means that the number of rows to be skipped should always be a multiple of two. An advanced subsampling scheme can be programmed to achieve these requirements. Of course, this advanced subsampling scheme can also be programmed in a monochrome sensor. See the table of registers below for more details.

| Image subsampling - advanced |                  |               |                                                                                                       |  |  |
|------------------------------|------------------|---------------|-------------------------------------------------------------------------------------------------------|--|--|
| Register name                | Register address | Default value | Description of the value                                                                              |  |  |
| Number_lines                 | 1-2              | 2048          | The value in this register defines the total number of lines read-out by the sensor (min=1, max=2048) |  |  |
| Sub_s                        | 35-36            | 0             | Should be '0' at all times                                                                            |  |  |
| Sub_a                        | 37-38            | 0             | Number of rows to skip, it should be an even number between (0 and 2046).                             |  |  |

The figures below give two subsampling examples (skip 4x and skip 2x) in advanced mode.



Figure 43: Subsampling examples in advanced mode (skip 4x and skip2x)

#### 5.6 Number of Frames

When internal exposure mode is selected, the number of frames sent by the sensor after a frame request can be programmed in the corresponding sequencer register.

| Number of frames |                                                             |   |                                                                                                                                              |  |  |
|------------------|-------------------------------------------------------------|---|----------------------------------------------------------------------------------------------------------------------------------------------|--|--|
| Register name    | ame Register address Default value Description of the value |   |                                                                                                                                              |  |  |
| Number_frames    | 70-71                                                       | 1 | The value in this register defines the number of frames grabbed and sent by the image sensor in internal exposure mode (min =1, max = 65548) |  |  |

#### 5.7 OUTPUT MODE

The number of LVDS channels can be selected by programming the appropriate sequencer register. The pixel remapping scheme and the read-out timing for each mode can be found in chapter 4 of this document.

| Output mode   |                                                                       |   |               |  |  |  |
|---------------|-----------------------------------------------------------------------|---|---------------|--|--|--|
| Register name | Register name Register address Default value Description of the value |   |               |  |  |  |
| Output_mode   | 72                                                                    | 0 | 0: 16 outputs |  |  |  |
|               |                                                                       |   | 1: 8 outputs  |  |  |  |
|               |                                                                       |   | 2: 4 outputs  |  |  |  |
|               |                                                                       |   | 3: 2 outputs  |  |  |  |

### 5.8 Training pattern

As detailed in chapter 4.6, a training pattern is sent over the LVDS data channels whenever no valid image data is sent. This training pattern can be programmed using the sequencer register.

| Training pattern |                  |               |                                                             |  |  |
|------------------|------------------|---------------|-------------------------------------------------------------|--|--|
| Register name    | Register address | Default value | Description of the value                                    |  |  |
| Training_pattern | 78-79            | 85            | The 12 LSBs of this 16 bit word are sent in 12-bit mode. In |  |  |
|                  |                  |               | 10 bit mode the 10 LSBs are sent.                           |  |  |

### 5.9 INTERNAL PLL

### 5.9.1 ENABLE PLL

When using the internal PLL it is no longer required to input a high speed LVDS clock; the internal PLL will create it itself depending on the register settings and the master input clock. Default the internal PLL is used. You can bypass the PLL with the following settings:

|               | Enable PLL                                              |   |                                                    |  |  |  |
|---------------|---------------------------------------------------------|---|----------------------------------------------------|--|--|--|
| Register name | Register address Default value Description of the value |   |                                                    |  |  |  |
| PII_bypass    | 115 bit[0]                                              | 0 | 0: Use the internal PLL 1: Bypass the internal PLL |  |  |  |

### 5.9.2 DATA RATE

During start-up or after a sequencer reset, the data rate can be changed if a lower speed than 480Mbps is desired. This can be done by applying a lower master input clock (CLK\_IN) to the sensor and uploading a new value in the PLL registers. See section 3.5 for more details on the input clock. See section 3.7 and 3.8 for details on how and when the data rate can be changed.

|                                                                       | PLL range |   |                                      |  |  |  |
|-----------------------------------------------------------------------|-----------|---|--------------------------------------|--|--|--|
| Register name Register address Default value Description of the value |           |   |                                      |  |  |  |
| PLL_IN_FRE                                                            | 114[1:0]  | 0 | 0: CLK_IN is between 20MHz and 48MHz |  |  |  |



# CMV4000 Datasheet

|               | PLL range                      |   |                                       |  |  |  |
|---------------|--------------------------------|---|---------------------------------------|--|--|--|
| Register name | Register address Default value |   | Description of the value              |  |  |  |
|               |                                |   | 1: CLK_IN is between 10MHz and 20MHz  |  |  |  |
|               |                                |   | 3: CLK_IN is between 5MHz and 10MHz   |  |  |  |
| PLL_OUT_FRE   | 116[6:4]                       | 5 | 5: CLK_IN is between 30MHz and 48MHz  |  |  |  |
|               |                                |   | 1: CLK_IN is between 15MHz and 30MHz  |  |  |  |
|               |                                |   | 0: CLK_IN is between 5MHz and 15MHz   |  |  |  |
| PLL_range     | 116[7]                         | 1 | 1: CLK_IN is between 30MHz and 48MHz  |  |  |  |
|               |                                |   | 0: CLK_IN is between 20MHz and 30MHz  |  |  |  |
|               |                                |   | 1: CLK_IN is between 15MHz and 20MHz  |  |  |  |
|               |                                |   | 0: CLK_IN is between 10MHz and 15MHz  |  |  |  |
|               |                                |   | 1: CLK_IN is between 7.5MHz and 10MHz |  |  |  |
|               |                                |   | 0: CLK_IN is between 5MHz and 7.5MHz  |  |  |  |

### 5.10 10-BIT OR 12-BIT MODE

The CMV4000 has the possibility to send 12 bits or 10 bits per pixel. The end user can select the desired resolution by programming the corresponding sequencer register. Always keep Bit\_mode and ADC\_Resolution in the same bit mode.

|                | 10-bit or 12-bit mode |                        |                          |  |  |  |
|----------------|-----------------------|------------------------|--------------------------|--|--|--|
| Register name  | Register address      | Default value          | Description of the value |  |  |  |
| Bit_mode       | 111                   | 1                      | 0: 12 bits per pixel     |  |  |  |
|                |                       |                        | 1: 10 bits per pixel     |  |  |  |
| ADC_Resolution | 112                   | 0 0: 10 bits per pixel |                          |  |  |  |
|                |                       |                        | 2: 12 bits per pixel     |  |  |  |
| PLL_load       | 117                   | 8 10 bit: set to 8     |                          |  |  |  |
|                |                       |                        | 12 bit: set to 4         |  |  |  |
| PLL_div        | 116[3:0]              | 9                      | 10 bit: set to 9         |  |  |  |
|                |                       |                        | 12 bit: set to 11        |  |  |  |

## 5.11 POWER CONTROL

The power consumption of the CMV4000 can be decreased by disabling the LVDS data channels when they are not used (in 8, 4 or 2 outputs mode). The power will decrease with approximately 18mW per channel. So reducing the outputs from 16 to 4 will save you about 216mW or 33%. This is the main source for power saving. Other settings (such as bitrate, fps, temperature ...) will have very little to no effect on the total power consumption.

| 10-bit or 12-bit mode                                                 |       |         |                                                  |  |  |
|-----------------------------------------------------------------------|-------|---------|--------------------------------------------------|--|--|
| Register name Register address Default value Description of the value |       |         |                                                  |  |  |
| Channel_en                                                            | 80-82 | All '1' | Bit 0-15 enable/disable the data output channels |  |  |
|                                                                       |       |         | Bit 16 enables/disables the clock channel        |  |  |
|                                                                       |       |         | Bit 17 enables/disables the control channel      |  |  |
|                                                                       |       |         | 0: disabled                                      |  |  |
|                                                                       |       |         | 1: enabled                                       |  |  |

Decreasing the master clock frequency and thereby the LVDS clock frequency will also decrease power consumption albeit little. Decreasing the LVDS\_CLK frequency from 480MHz to 128MHz will decrease power consumption with about 25mW.

All power savings will happen on the VDD20 supply.

Other settings or factors have little to no effect on the power consumption.

### 5.12 OFFSET AND GAIN

### **5.12.1 OFFSET**

A digital offset can be applied to the output signal. This dark level offset can be programmed by setting the desired value in the sequencer register. The 14 bit register value is a 2-complement number, allowing us to have a positive and a negative offset (from 8191 to -8192). The ADC itself has a fixed offset of 70.

So the dark-level @ output = 70 + Offset (in 2's complement). For example register value 16323 (11 1111 1100 0011) equals -61 in 2's complement. The default dark-level is thus set at 70 -61 = 9 digital numbers.

|               | Offset           |               |                     |                          |                     |  |  |
|---------------|------------------|---------------|---------------------|--------------------------|---------------------|--|--|
| Register name | Register address | Default value |                     | Description of the value |                     |  |  |
| Offset        | 100-101          | 16323         | The value in thi    | is register defines the  | e dark level offset |  |  |
|               |                  |               | applied to the ou   | tput signal (min = 0, ma | ax = 16383).        |  |  |
|               |                  |               | The value is in 2's | complement:              |                     |  |  |
|               |                  |               | Decimal             | Binary                   | 2's Comp.           |  |  |
|               |                  |               | 0                   | 00 0000 0000 0000        | 0                   |  |  |
|               |                  |               | 1                   | 00 0000 0000 0001        | 1                   |  |  |
|               |                  |               |                     |                          |                     |  |  |
|               |                  |               | 8191                | 01 1111 1111 1111        | 8191                |  |  |
|               |                  |               | 8192                | 10 0000 0000 0000        | -8192               |  |  |
|               |                  |               | 8193                | 10 0000 0000 0001        | -8191               |  |  |
|               |                  |               |                     |                          |                     |  |  |
|               |                  |               | 16383               | 11 1111 1111 1111        | -1                  |  |  |
|               |                  |               |                     |                          |                     |  |  |

### 5.12.2 GAIN

An analog gain and ADC gain can be applied to the output signal. The analog gain is applied by a PGA in every column. The digital gain is applied by the ADC.

|               | Gain                       |               |                          |  |  |  |  |  |
|---------------|----------------------------|---------------|--------------------------|--|--|--|--|--|
| Register name | Register address           | Default value | Description of the value |  |  |  |  |  |
| PGA           | 121 bit[0] + 102 bits[1:0] | 0             | 0: x1 gain               |  |  |  |  |  |
|               |                            |               | 1: x1.2 gain             |  |  |  |  |  |
|               |                            |               | 2: x1.4 gain             |  |  |  |  |  |
|               |                            |               | 3: x1.6 gain             |  |  |  |  |  |
|               |                            |               | 4: x2 gain               |  |  |  |  |  |
|               |                            |               | 5: x2.4gain              |  |  |  |  |  |
|               |                            |               | 6: x2.8 gain             |  |  |  |  |  |
|               |                            |               | 7: x3.2 gain             |  |  |  |  |  |
| ADC_gain      | 103                        | 32            | 32                       |  |  |  |  |  |

The ADC gain is dependent on the master clock. A slower clock signal means a higher ADC\_gain register value for an actual ADC gain of 1x. Also at higher register values, the actual ADC gain will increase in bigger steps. So fine-tuning the ADC gain is easier at lower register values. Below you can find typical graphs regarding these settings.



Figure 44: Actual ADC gain vs. ADC register value [103]

### 5.13 BLACK REFERENCE COLUMNS

When the appropriate SPI register is set, the 16 first columns will be put to an electrical black reference. This electrical black reference can be used to reduce the row noise and/or track black level.

| Black columns |                  |               |                          |  |  |  |
|---------------|------------------|---------------|--------------------------|--|--|--|
| Register name | Register address | Default value | Description of the value |  |  |  |
| Black_col_en  | 121 bits[1]      | 0             | 0 : disable              |  |  |  |
|               |                  |               | 1 : enable               |  |  |  |

### 5.14 HORIZONTAL LINE EFFECT DURING EXPOSURE START

When the exposure of an image frame is started while a previous image frame is read out this action may become visible in the image frame currently read out. The effect is visible in the line addressed for read-out at the moment the exposure of the next image frame starts. Depending on the moment when the exposure starts within the line read-out time, this will result in a bright or dark offset for the addressed line. This horizontal line artifact is due to the cross-talk of the global transfer gate pulse on the column readout.

This problem is solved by changing the sequencer timing. At the moment the global transfer is pulsed, a programmable number of dummy rows can be inserted in the readout. This means that the transfer pulse crosstalk does not influence valid data rows.

The exact internal impact of the new timing depends on the readout and exposure modes (PLR, internal or external exposure control...). Externally, the only impact is that the DVAL and LVAL outputs are not pulsed for a number of row periods. The external system should always monitor the DVAL, LVAL and FVAL pulses to know when valid pixels, lines and frames become available. Next figure shows the timing (in case of 2 dummy rows).





Figure 45: Timing of DVAL, LVAL and FVAL to avoid horizontal line arTifact

By default, no dummy rows are inserted in the readout. The dummy rows are enabled by loading the appropriate values to the register inte\_sync and dummy.

| Dummy rows    |                  |               |                                        |  |  |  |  |
|---------------|------------------|---------------|----------------------------------------|--|--|--|--|
| Register name | Register address | Default value | Description of the value               |  |  |  |  |
| inte_sync     | 41 bits[2]       | 0             | Must be set to 1 if reg_dummy is not 0 |  |  |  |  |
| dummy         | 118 bits[7:0]    | 0             | Sets the number of dummy rows          |  |  |  |  |
|               |                  |               |                                        |  |  |  |  |

Note that the register 'dummy' sets the number of dummy rows (one row corresponds to one LVAL pulse). In multiplex modes, there are several timing slots within a single row readout. In case dual exposure is used, the dummy rows are generated for both transfer pulse toggles.

## 5.15 RECOMMENDED REGISTER SETTINGS

The following table gives an overview of the registers which have a required value which is different from their default start-up value. We strongly recommend to load these register settings after start-up and before grabbing an image.

| Address | Name        | Required Value |
|---------|-------------|----------------|
| 103     | ADC_GAIN    | 41             |
| 74      | I_lvds_rec  | 0              |
| 86      | I_adc       | 14             |
| 87      | I_amp       | 12             |
| 84      | I_col       | 4              |
| 85      | I_col_prech | 1              |
| 88      | Vtf_l1      | 64             |
| 91      | Vres_low    | 64             |
| 94      | V_precharge | 101            |
| 98      | V_ramp1     | 109            |
| 99      | V_ramp2     | 109            |
| 95      | V_ref       | 106            |
| 123     | V_blacksun  | 98             |
| 77      | Col_calib   | 0              |



### 5.15.1 ADJUSTING REGISTERS FOR OPTIMAL PERFORMANCE

Due to processing differences, the response and optical performance may differ slightly from sensor to sensor. To adjust this difference in response, the following registers should be tuned from sensor to sensor.

| Address | Name     | Required Value | Valid Range |
|---------|----------|----------------|-------------|
| 103     | ADC_GAIN | See 5.12.2     | 0 - 63      |
| 98      | V_ramp1  | 109            | 102-115     |
| 99      | V_ramp2  | 109            | 102-115     |

- ADC\_gain: Due to processing differences, the AFE (analog front end) of the sensor may differ from device to device. This means that the total gain value (bit/e) of the sensor may differ from sensor to sensor. The ADC\_gain register can be used to change the gain value (bit/e) from every sensor to match a desired value.
- V\_ramp1/2: When column non-uniformities are observed with the default and recommended (chapter 5.15) register settings an adjustment of the V\_ramp1/2 registers is advised. These registers set the starting voltage of the ramp used by the column ramp ADC. Adjusting this value will result in better column CDS (correlated double sampling) which will remove the column FPN from the image. Both values always should have the same value.



# 6 REGISTER OVERVIEW

The table below gives an overview of all the sensor registers. The registers with the remark "Do not change" should not be changed unless advised in chapter 5.13.

|         | Register overview |                     |                                        |        |       |          |          |      |       |          |     |     |        |                |
|---------|-------------------|---------------------|----------------------------------------|--------|-------|----------|----------|------|-------|----------|-----|-----|--------|----------------|
| Address | Default           |                     |                                        |        |       | \        | /alue    | •    |       |          |     |     |        | Remark/        |
|         |                   | D:+[7]              | D:+[C]                                 | D:+[E  | D:+I  | 41       | D:+[·    | 21   | D:+[3 | <b>.</b> | D:+ | [4] | D:+[O] | Required value |
| 0       | 0                 | Bit[7]              | Bit[6]                                 | Bit[5] | ] Bit | 4]       | Bit[     | 3]   | Bit[2 | <u> </u> | Bit | [1] | Bit[0] | Do not shange  |
| 0       | 0                 |                     |                                        |        | NI.   | م ما ممی | بمائل من | [7./ | 01    |          |     |     |        | Do not change  |
| 1       | 0<br>8            |                     |                                        |        |       |          | r_line   |      | _     |          |     |     |        |                |
| 3       |                   |                     |                                        |        | Nu    |          | r lines  |      | 8]    |          |     |     |        |                |
|         | 0                 |                     |                                        |        |       |          | rt1[7    |      |       |          |     |     |        |                |
| 4       | 0                 |                     |                                        |        |       |          | t1[15    |      |       |          |     |     |        |                |
| 5<br>6  | 0                 |                     |                                        |        |       |          | rt2[7    |      |       |          |     |     |        |                |
|         | 0                 |                     |                                        |        |       |          | t2[15    |      |       |          |     |     |        |                |
| 7       | 0                 |                     |                                        |        |       |          | rt3[7    |      |       |          |     |     |        |                |
| 8       | 0                 |                     |                                        |        |       |          | t3[15    |      |       |          |     |     |        |                |
| 9       | 0                 |                     |                                        |        |       |          | rt4[7    |      |       |          |     |     |        |                |
| 10      | 0                 |                     |                                        |        |       |          | t4[15    |      |       |          |     |     |        |                |
| 11      | 0                 |                     |                                        |        |       |          | rt5[7    |      |       |          |     |     |        |                |
| 12      | 0                 |                     |                                        |        |       |          | t5[15    |      |       |          |     |     |        |                |
| 13      | 0                 |                     |                                        |        |       |          | rt6[7    |      |       |          |     |     |        |                |
| 14      | 0                 |                     |                                        |        |       |          | t6[15    |      |       |          |     |     |        |                |
| 15      | 0                 |                     |                                        |        |       |          | rt7[7    | _    |       |          |     |     |        |                |
| 16      | 0                 |                     |                                        |        |       |          | t7[15    |      |       |          |     |     |        |                |
| 17      | 0                 |                     |                                        |        |       |          | rt8[7    |      |       |          |     |     |        |                |
| 18      | 0                 |                     |                                        |        | NI    |          | t8[15    |      | .01   |          |     |     |        |                |
| 19      | 0                 |                     |                                        |        |       |          | r_line   |      |       |          |     |     |        |                |
| 20      | 0                 |                     |                                        |        |       |          | _lines   |      |       |          |     |     |        |                |
| 21      | 0                 |                     |                                        |        |       |          | r_line   |      |       |          |     |     |        |                |
| 22      | 0                 |                     |                                        |        |       |          | _lines   |      |       |          |     |     |        |                |
| 23      | 0                 |                     |                                        |        |       |          | r_line   |      |       |          |     |     |        |                |
| 24      | 0                 |                     |                                        |        |       |          | _lines   |      |       |          |     |     |        |                |
| 25      | 0                 |                     |                                        |        |       |          | r_line   |      |       |          |     |     |        |                |
| 26      | 0                 |                     | Number_lines4[15:8]                    |        |       |          |          |      |       |          |     |     |        |                |
| 27      | 0                 |                     | Number_lines5[7:0] Number_lines5[15:8] |        |       |          |          |      |       |          |     |     |        |                |
| 28      | 0                 |                     |                                        |        |       |          |          |      |       |          |     |     |        |                |
| 29      | 0                 |                     |                                        |        |       |          | r_line   |      |       |          |     |     |        |                |
| 30      | 0                 |                     |                                        |        |       |          | _lines   |      |       |          |     |     |        |                |
| 31      | 0                 |                     |                                        |        |       |          | r_line   |      |       |          |     |     |        |                |
| 32      | 0                 |                     | Number_lines7[15:8]                    |        |       |          |          |      |       |          |     |     |        |                |
| 33      | 0                 | Number_lines8[7:0]  |                                        |        |       |          |          |      |       |          |     |     |        |                |
| 34      | 0                 |                     | Number_lines8[15:8]                    |        |       |          |          |      |       |          |     |     |        |                |
| 35      | 0                 | Sub_s[7:0]          |                                        |        |       |          |          |      |       |          |     |     |        |                |
| 36      | 0                 |                     | Sub_s[15:8]                            |        |       |          |          |      |       |          |     |     |        |                |
| 37      | 0                 |                     | Sub_a[7:0]                             |        |       |          |          |      |       |          |     |     |        |                |
| 38      | 0                 | Sub_a[15:8]         |                                        |        |       |          |          |      |       |          |     |     |        |                |
| 39      | 1                 | Color               |                                        |        |       |          |          |      |       |          |     |     |        |                |
| 40      | 0                 | Image_flipping[1:0] |                                        |        |       |          |          |      |       |          |     |     |        |                |
| 41      | 0                 |                     | Inte_sync Exp_dual Exp_ext             |        |       |          |          |      |       |          |     |     |        |                |
| 42      | 0                 |                     | Exp_time[7:0]                          |        |       |          |          |      |       |          |     |     |        |                |
| 43      | 8                 |                     | Exp_time[15:8]  Exp_time[23:16]        |        |       |          |          |      |       |          |     |     |        |                |
| 44      | 0                 |                     |                                        |        |       |          |          |      | J     |          |     |     |        |                |
| 45      | 0                 |                     | Exp_step[7:0]                          |        |       |          |          |      |       |          |     |     |        |                |



# CMV4000 Datasheet

|         |         | Register overview                                                                                               |                |  |  |  |  |
|---------|---------|-----------------------------------------------------------------------------------------------------------------|----------------|--|--|--|--|
| Address | Default | Value                                                                                                           | Remark/        |  |  |  |  |
|         |         |                                                                                                                 | Required value |  |  |  |  |
|         |         | Bit[7]         Bit[6]         Bit[5]         Bit[4]         Bit[3]         Bit[2]         Bit[1]         Bit[0] |                |  |  |  |  |
| 46      | 0       | Exp_step[15:8]                                                                                                  |                |  |  |  |  |
| 47      | 0       | Exp_step[23:16]                                                                                                 |                |  |  |  |  |
| 48      | 1       | Exp_kp1[7:0]                                                                                                    |                |  |  |  |  |
| 49      | 0       | Exp_kp1[15:8]                                                                                                   |                |  |  |  |  |
| 50      | 0       | Exp_kp1[23:16]                                                                                                  |                |  |  |  |  |
| 51      | 1       | Exp_kp2[7:0]                                                                                                    |                |  |  |  |  |
| 52      | 0       | Exp_kp2[15:8]                                                                                                   |                |  |  |  |  |
| 53      | 0       | Exp_kp2[23:16]                                                                                                  |                |  |  |  |  |
| 54      | 1       | Nr_slopes[1:0]                                                                                                  |                |  |  |  |  |
| 55      | 1       | Exp_seq[7:0]                                                                                                    |                |  |  |  |  |
| 56      | 0       | Exp_time2[7:0]                                                                                                  |                |  |  |  |  |
| 57      | 8       | Exp_time2[15:8]                                                                                                 |                |  |  |  |  |
| 58      | 0       | Exp_time2[23:16]                                                                                                |                |  |  |  |  |
| 59      | 0       | Exp_step2[7:0]                                                                                                  |                |  |  |  |  |
| 60      | 0       | Exp_step2[15:8]                                                                                                 |                |  |  |  |  |
| 61      | 0       | Exp_step2[23:16]                                                                                                |                |  |  |  |  |
| 62      | 1       | · <u>-</u> · · ·                                                                                                | Do not change  |  |  |  |  |
| 63      | 0       |                                                                                                                 | Do not change  |  |  |  |  |
| 64      | 0       |                                                                                                                 | Do not change  |  |  |  |  |
| 65      | 1       |                                                                                                                 | Do not change  |  |  |  |  |
| 66      | 0       |                                                                                                                 | Do not change  |  |  |  |  |
| 67      | 0       |                                                                                                                 | Do not change  |  |  |  |  |
| 68      | 1       | Nr_slopes2[1:0]                                                                                                 |                |  |  |  |  |
| 69      | 1       | Exp2_seq[7:0]                                                                                                   |                |  |  |  |  |
| 70      | 1       | Number_frames [7:0]                                                                                             |                |  |  |  |  |
| 71      | 0       | Number_frames[15:8]                                                                                             |                |  |  |  |  |
| 72      | 0       | Output_mode[1:0]                                                                                                |                |  |  |  |  |
| 73      | 20      |                                                                                                                 | Do not change  |  |  |  |  |
| 74      | 8       |                                                                                                                 | Set to 0       |  |  |  |  |
| 75      | 8       |                                                                                                                 | Do not change  |  |  |  |  |
| 76      | 8       |                                                                                                                 | Do not change  |  |  |  |  |
| 77      | 3       |                                                                                                                 | Set to 0       |  |  |  |  |
| 78      | 85      | Training_pattern[7:0]                                                                                           | 361100         |  |  |  |  |
| 79      | 0       | Training pattern [11:8]                                                                                         |                |  |  |  |  |
| 80      | 255     | Channel_en[7:0]                                                                                                 |                |  |  |  |  |
| 81      | 255     | Channel_en[15:8]                                                                                                |                |  |  |  |  |
| 82      | 3       | Channel en[17:16]                                                                                               |                |  |  |  |  |
| 83      | 8       | Channel_en[17.10]                                                                                               | Do not change  |  |  |  |  |
| 84      | 8       |                                                                                                                 | Set to 4       |  |  |  |  |
| 85      | 8       |                                                                                                                 | Set to 4       |  |  |  |  |
| 86      | 8       |                                                                                                                 | Set to 14      |  |  |  |  |
| 87      | 8       |                                                                                                                 | Set to 14      |  |  |  |  |
| 88      | 96      |                                                                                                                 | Set to 12      |  |  |  |  |
|         |         | \/ au/2[7:0]                                                                                                    | 361 10 04      |  |  |  |  |
| 89      | 96      | Vlow2[7:0]                                                                                                      |                |  |  |  |  |
| 90      | 96      | Vlow3[7:0]                                                                                                      |                |  |  |  |  |
| 91      | 96      |                                                                                                                 | Set to 64      |  |  |  |  |
| 92      | 96      |                                                                                                                 | Do not change  |  |  |  |  |
| 93      | 96      |                                                                                                                 | Do not change  |  |  |  |  |
| 94      | 96      |                                                                                                                 | Set to 101     |  |  |  |  |
| 95      | 96      |                                                                                                                 | Set to 106     |  |  |  |  |
| 96      | 96      |                                                                                                                 | Do not change  |  |  |  |  |



|         | Register overview |                                                                                                                 |                   |  |  |  |  |  |
|---------|-------------------|-----------------------------------------------------------------------------------------------------------------|-------------------|--|--|--|--|--|
| Address | Default           | Value                                                                                                           | Remark/           |  |  |  |  |  |
|         |                   |                                                                                                                 | Required value    |  |  |  |  |  |
|         |                   | Bit[7]         Bit[6]         Bit[5]         Bit[4]         Bit[3]         Bit[2]         Bit[1]         Bit[0] |                   |  |  |  |  |  |
| 97      | 96                |                                                                                                                 | Do not change     |  |  |  |  |  |
| 98      | 96                |                                                                                                                 | Set to 109 (can   |  |  |  |  |  |
|         |                   |                                                                                                                 | differ from       |  |  |  |  |  |
|         |                   |                                                                                                                 | sensor to sensor) |  |  |  |  |  |
| 99      | 96                |                                                                                                                 | Set to 109 (can   |  |  |  |  |  |
|         |                   |                                                                                                                 | differ from       |  |  |  |  |  |
|         |                   |                                                                                                                 | sensor to sensor) |  |  |  |  |  |
| 100     | 195               | Offset[7:0]                                                                                                     |                   |  |  |  |  |  |
| 101     | 63                | Offset[13:8]                                                                                                    |                   |  |  |  |  |  |
| 102     | 0                 | PGA[1:0]                                                                                                        |                   |  |  |  |  |  |
| 103     | 32                | ADC_gain[7:0]                                                                                                   | Set to 41         |  |  |  |  |  |
| 104     | 8                 |                                                                                                                 | Do not change     |  |  |  |  |  |
| 105     | 8                 |                                                                                                                 | Do not change     |  |  |  |  |  |
| 106     | 8                 |                                                                                                                 | Do not change     |  |  |  |  |  |
| 107     | 8                 |                                                                                                                 | Do not change     |  |  |  |  |  |
| 108     | 0                 |                                                                                                                 | Do not change     |  |  |  |  |  |
| 109     | 1                 |                                                                                                                 | Do not change     |  |  |  |  |  |
| 110     | 0                 |                                                                                                                 | Do not change     |  |  |  |  |  |
| 111     | 1                 | Bit_mode[0]                                                                                                     |                   |  |  |  |  |  |
| 112     | 0                 | ADC_resolution[1:0]                                                                                             |                   |  |  |  |  |  |
| 113     | 1                 |                                                                                                                 | Do not change     |  |  |  |  |  |
| 114     | 0                 | PLL_IN_FRE[1:0]                                                                                                 |                   |  |  |  |  |  |
| 115     | 0                 |                                                                                                                 | Do not change     |  |  |  |  |  |
| 116     | 217               | PLL_range[1] PLL_OUT_FRE[6:4] PLL_div[3:0]                                                                      |                   |  |  |  |  |  |
| 117     | 8                 | PLL_load                                                                                                        |                   |  |  |  |  |  |
| 118     | 0                 | <br>Dummy[7:0]                                                                                                  | Set to 1          |  |  |  |  |  |
| 119     | 0                 | · · ·                                                                                                           | Do not change     |  |  |  |  |  |
| 120     | 0                 |                                                                                                                 | Do not change     |  |  |  |  |  |
| 121     | 0                 | Black_col_en[1] PGA[2]                                                                                          | j                 |  |  |  |  |  |
| 122     | 0                 |                                                                                                                 | Do not change     |  |  |  |  |  |
| 123     | 64                |                                                                                                                 | Set to 98         |  |  |  |  |  |
| 124     | 0                 |                                                                                                                 | Do not change     |  |  |  |  |  |
| 125     | 67                | Do n                                                                                                            |                   |  |  |  |  |  |
| 126     | 0                 | Temp[7:0]                                                                                                       | 3-                |  |  |  |  |  |
| 127     | 0                 | Temp[15:8]                                                                                                      |                   |  |  |  |  |  |

Note: The default value of the "do not change" registers should not be overwritten unless recommended in chapter 5.13.

Register 125 can be used to verify which sensor is used:

| Reg 125 value | Sensor type |
|---------------|-------------|
| 32            | CMV2000 v2  |
| 35            | CMV2000 v3  |
| 64            | CMV4000 v2  |
| 67            | CMV4000 v3  |



## 7 MECHANICAL SPECIFICATIONS

### 7.1 PACKAGE DRAWING



Figure 46: PGA package drawing of the CMV4000. All dimensions are in mm.

We also have an LGA package (SMD), which is identical to the PGA but without the through-hole pins.



## 7.2 ASSEMBLY DRAWING



Figure 47: Assembly drawing of CMV4000

## 7.3 COVER GLASS

The cover glass of the CMV4000 is plain D263 glass with a transmittance as shown in figure 37. Refraction index of the glass is 1.52. Scratch, bubbles and digs shall be less than or equal to 0.02 mm

When a color sensor is used an IR-cutoff filter should be placed in the optical path of the sensor.



Figure 48: Transmittance curve of D263 cover glass



### 7.4 COLOR FILTERS

When a color version of the CMV4000 is used, the color filters are applied in a Bayer pattern. The color version of the CMV4000 always has microlenses. The typical spectral response of the CMV with color filters and D263 cover glass can be found below. The use of an IR cut-off filter in the optical path of the CMV4000 image sensor is necessary to obtain good color separation when using light with an NIR component.



Figure 49: Typical spectral response of CMV4000 with RGB color filters and D263 cover glass

A RGB Bayer pattern is used on the CMV4000 image sensor. The order of the RGB filter can be found in the drawing below. When Y-flipping is off (register 40 = 0), pixel(0,0) is at top left and has a red filter.



Figure 50: RGB Bayer pattern order



# 8 Typical response

Below you can see a typical response curve of integration time (or light input) versus the average output value of the sensor.



Figure 51: Typical response curve



# 9 SPECTRAL RESPONSE

# 9.1 5 µM EPI DEVICES

The typical spectral response of a monochrome CMV4000 with microlenses can be found below.



Figure 52: typical spectral response of the CMV4000

## 9.2 12μM EPI DEVICES

A variation from the standard CMV2000 image sensors is processed on 12  $\mu$ m epi (E12) Si wafers. The thicker epi-layer wafer starting material increases significantly the QE for wavelengths above 600 nm. Around 900 nm the QE is about doubled and increases from 8% to 16%.



Figure 53: Response of E12 devices vs. normal devices



# 10 PINNING

# **10.1** PIN LIST

The pin list of the CMV4000 can be found below

| Pin number | Pin name   | Description                                         | Туре        |
|------------|------------|-----------------------------------------------------|-------------|
| A2         | OUT2_N     | LVDS negative data output channel 2                 | LVDS output |
| A3         | OUT2_P     | LVDS positive data output channel 2                 | LVDS output |
| A4         | OUT5_N     | LVDS negative data output channel 5                 | LVDS output |
| A5         | OUT5 P     | LVDS positive data output channel 5                 | LVDS output |
| A6         | GND        | Ground pin                                          | Ground      |
| A7         | VDD20      | 2.0V supply                                         | Supply      |
| A8         | OUT12_N    | LVDS negative data output channel 12                | LVDS output |
| A9         | OUT12_P    | LVDS positive data output channel 12                | LVDS output |
| A10        | OUT15_N    | LVDS negative data output channel 15                | LVDS output |
| A11        | OUT15 P    | LVDS positive data output channel 15                | LVDS output |
| A12        | GND        | Ground pin                                          | Ground      |
| B1         | OUTCTR_N   | LVDS negative control output channel                | LVDS output |
| B2         | OUTCTR_P   | LVDS positive control output channel                | LVDS output |
| B3         | OUT4_N     | LVDS negative data output channel 4                 | LVDS output |
| B4         | OUT4 P     | LVDS positive data output channel 4                 | LVDS output |
| B5         | OUT7 N     | LVDS negative data output channel 7                 | LVDS output |
| B6         | OUT7 P     | LVDS positive data output channel 7                 | LVDS output |
| B7         | OUT10 N    | LVDS negative data output channel 10                | LVDS output |
| B8         | OUT10 P    | LVDS positive data output channel 10                | LVDS output |
| B9         | OUT13_N    | LVDS negative data output channel 13                | LVDS output |
| B10        | OUT13 P    | LVDS positive data output channel 13                | LVDS output |
| B11        | OUTCLK N   | LVDS negative clock output channel                  | LVDS output |
| B12        | OUTCLK P   | LVDS positive clock output channel                  | LVDS output |
| C1         | GND        | Ground pin                                          | Ground      |
| C2         | OUT1_N     | LVDS negative data output channel 1                 | LVDS output |
| C3         | OUT1_P     | LVDS positive data output channel 1                 | LVDS output |
| C4         | OUT6 N     | LVDS negative data output channel 6                 | LVDS output |
| C5         | OUT6 P     | LVDS positive data output channel 6                 | LVDS output |
| C6         | GND        | Ground pin                                          | Ground      |
| C7         | VDD20      | 2.0V supply                                         | Supply      |
| C8         | OUT11_N    | LVDS negative data output channel 11                | LVDS output |
| C9         | OUT11 P    | LVDS positive data output channel 11                | LVDS output |
| C10        | OUT16_N    | LVDS negative data output channel 16                | LVDS output |
| C11        | OUT16_P    | LVDS positive data output channel 16                | LVDS output |
| C12        | GND        | Ground pin                                          | Ground      |
| D1         | LVDS_CLK_P | LVDS input clock P                                  | LVDS input  |
| D2         | LVDS_CLK_N | LVDS input clock N                                  | LVDS input  |
| D3         | OUT3_N     | LVDS negative data output channel 3                 | LVDS output |
| D4         | OUT3_P     | LVDS positive data output channel 3                 | LVDS output |
| D5         | OUT8_N     | LVDS negative data output channel 8                 | LVDS output |
| D6         | OUT8_P     | LVDS positive data output channel 8                 | LVDS output |
| D7         | OUT9_N     | LVDS negative data output channel 9                 | LVDS output |
| D8         | OUT9_P     | LVDS positive data output channel 9                 | LVDS output |
| D9         | OUT14 N    | LVDS negative data output channel 14                | LVDS output |
| D10        | OUT14 P    | LVDS positive data output channel 14                | LVDS output |
| D11        | VREF       | Ref for column amps (decouple with 100nF to ground) | Bias        |
| D12        | REF_ADC    | Ref for ADC testing (decouple with 100nF to ground) | Bias        |



# **CMV4000 Datasheet**

| Pin number | Pin name  | Description                                               | Туре           |
|------------|-----------|-----------------------------------------------------------|----------------|
| E1         | CLK_IN    | Master input clock                                        | Digital input  |
| E2         | VDD33     | 3.3V supply                                               | Supply         |
| E3         | GND       | Ground pin                                                | Ground         |
| E4         | VDD20     | 2.0V supply                                               | Supply         |
| E5         | GND       | Ground pin                                                | Ground         |
| E6         | VDDpix    | 3.0V supply                                               | Supply         |
| E7         | VDD20     | 2.0V supply                                               | Supply         |
| E8         | VDD20     | 2.0V supply                                               | Supply         |
| E9         | GND       | Ground pin                                                | Ground         |
| E10        | SG ADC    | Sig for ADC testing (decouple with 100nF to ground)       | Bias           |
| E11        | Vramp1    | Start voltage first ramp (decouple with 100nF to ground)  | Bias           |
| E12        | Vramp2    | Start voltage second ramp (decouple with 100nF to ground) | Bias           |
| F1         | GND       | Ground pin                                                | Ground         |
| F2         | FRAME_REQ | Frame request pin                                         | Digital input  |
| F3         | SPI IN    | SPI data input pin                                        | Digital input  |
| F4         | SPI OUT   | SPI data output pin                                       | Digital output |
| F5         | CMD P INV | decouple with 100nF to VDD33                              | bias           |
| F6         | Vpch H    | Precharge high voltage (decouple with 100nF to ground)    | bias           |
| F7         | Vres H    | 3.3V supply                                               | Supply         |
| F8         | Vtf I2    | Transfer low voltage 2 (decouple with 100nF to ground)    | Bias           |
| F9         | Col load  |                                                           | Bias           |
| F10        | _         | decouple with 100nF to ground                             |                |
|            | ramp      | decouple with 100nF to VDD33                              | Bias           |
| F11        | DIO1      | Diode 1 for test (not connected)                          | Test           |
| F12        | GND       | Ground pin                                                | Ground         |
| G1<br>G2   | VDDpix    | 3.0V supply                                               | Supply         |
| G2<br>G3   | T_dig2    | Test pin for digital signals                              | Digital output |
|            | T_Exp2    | Input pin for external exposure mode                      | Digital input  |
| G4         | SPI_EN    | SPI enable input pin                                      | Digital input  |
| G5         | CMD_P     | decouple with 100nF to VDD33                              | bias           |
| G6         | CMD_N     | decouple with 100nF to ground                             | bias           |
| G7         | Tana      | Test pin for analog signals                               | Analog output  |
| G8         | Vtf_l1    | Transfer low voltage 1 (connect to ground)                | Bias           |
| G9         | Col_amp   | decouple with 100nF to ground                             | Bias           |
| G10        | ADC       | decouple with 100nF to VDD33                              | Bias           |
| G11        | Vbgap     | decouple with 100nF to ground                             | Bias           |
| G12        | VDDpix    | 3.0V supply                                               | Supply         |
| H1         | VDD33     | 3.3V supply                                               | Supply         |
| H2         | T_dig1    | Test pin for digital signals                              | Digital output |
| H3         | T_Exp1    | Input pin for external exposure mode                      | Digital input  |
| H4         | SPI_CLK   | SPI clock input pin                                       | Digital input  |
| H5         | SYS_RES_N | Input pin for sequencer reset                             | Digital input  |
| H6         | VDD33     | 3.3V supply                                               | Supply         |
| H7         | GND       | Ground pin                                                | Ground         |
| H8         | Vres_L    | Res low voltage (decouple with 100nF to ground)           | Bias           |
| Н9         | Vtf_l3    | Transfer low voltage 3 (decouple with 100nF to ground)    | bias           |
| H10        | COL_PC    | decouple with 100nF to ground                             | Bias           |
| H11        | LVDS      | decouple with 100nF to ground                             | Bias           |
| H12        | DIO2      | Diode 2 for test (not connected)                          | Test           |

Analog and digital ground can be tied together.

# 10.2 PIN LAYOUT

This is the pin layout seen from a top view.



|   | 1              | 2              | 3      | 4       | 5             | 6      | 7       | 8       | 9        | 10      | 11           | 12           |
|---|----------------|----------------|--------|---------|---------------|--------|---------|---------|----------|---------|--------------|--------------|
| A |                | OUT2_N         | OUT2_P | OUT5_N  | OUT5_P        | GND    | VDD20   | OUT12_N | OUT12_P  | OUT15_N | OUT15_P      | GND          |
| В | OUT<br>CTR_N   | OUT<br>CTR_P   | OUT4_N | OUT4_P  | OUT7_N        | OUT7_P | OUT10_N | OUT10_P | OUT13_N  | OUT13_P | OUT<br>CLK_N | OUT<br>CLK_P |
| С | GND            | OUT1_N         | OUT1_P | OUT6_N  | OUT6_P        | GND    | VDD20   | OUT11_N | OUT11_P  | OUT16_N | OUT16_P      | GND          |
| D | LVDS_<br>CLK_P | LVDS_<br>CLK_N | OUT3_N | OUT3_P  | OUT8_N        | OUT8_P | OUT9_N  | OUT9_P  | OUT14_N  | OUT14_P | VREF         | REF_ADC      |
| E | CLK_IN         | VDD33          | GND    | VDD20   | GND           | VDDpix | VDD20   | VDD20   | GND      | SG_ADC  | Vramp1       | Vramp2       |
| F | GND            | FRAME<br>_REQ  | SPI_IN | SPI_OUT | CMD_P<br>_INV | Vpch_H | Vres_H  | Vtf_l2  | Col_load | ramp    | DIO1         | GND          |
| G | VDDpix         | T_dig2         | T_Exp2 | SPI_EN  | CMD_P         | CMD_N  | Tana    | Vtf_l1  | Col_amp  | ADC     | Vbgap        | VDDpix       |
| н | VDD33          | T_dig1         | T_Exp1 | SPI_CLK | SYS_<br>RES_N | VDD33  | GND     | Vres_L  | Vtf_l3   | COL_PC  | LVDS         | DIO2         |

Figure 54: Pin Layout



# 11 Specification overview

| Specification      | Value                     | Comment                                         |
|--------------------|---------------------------|-------------------------------------------------|
| Effective pixels   | 2048 x 2048               |                                                 |
| Pixel pitch        | 5.5 x 5.5 μm <sup>2</sup> |                                                 |
| Optical format     | 1"                        |                                                 |
| Full well charge   | 13.5 Ke-                  | Pinned photodiode pixel.                        |
| Conversion gain    | 0.075 LSB/e-              | 10 bit mode, unity gain                         |
| Sensitivity        | 5.56 V/lux.s              | With microlenses @ 550nm                        |
| ,                  | 0.27 A/W                  | <u> </u>                                        |
| Temporal noise     | 13 e-                     | Pipelined global shutter (GS) with correlated   |
| (analog domain)    |                           | double sampling (CDS). Read-noise               |
| Dynamic range      | 60 dB                     |                                                 |
| Pixel type         | Global shutter            | Allows fixed pattern noise correction and reset |
|                    | pixel                     | (kTC) noise canceling through correlated        |
|                    |                           | double sampling.                                |
| Shutter type       | Pipelined global          | Exposure of next image during readout of the    |
|                    | shutter                   | previous image.                                 |
| Parasitic light    | <1/50 000                 |                                                 |
| sensitivity -      |                           |                                                 |
| Shutter efficiency | >99.998%                  |                                                 |
| Color filters      | Optional                  | RGB Bayer pattern                               |
| Micro lenses       | Yes                       |                                                 |
| Fill Factor        | 42%                       | w/o micro lens                                  |
| QE * FF            | 60%                       | @ 550 nm with micro lenses.                     |
| Dark current       | 125 e/s                   | @ 25C die temperature. The dark current         |
| signal             |                           | ~doubles with every 6.5°C increase              |
| DSNU               | 3 LSB/s                   | 10 bit mode                                     |
| Fixed pattern      | <1 LSB RMS                | <0.1% of full swing, 10 bit mode                |
| noise              |                           |                                                 |
| PRNU               | < 1% RMS of               |                                                 |
|                    | signal                    |                                                 |
| LVDS Output        | 16                        | Each data output running @ 480 Mbit/s.          |
| channel            |                           | 8, 4 and 2 outputs selectable at reduced frame  |
|                    |                           | rate                                            |
| Frame rate         | 180 frames/s              | Using a 10bit/pixel and 480 Mbit/s LVDS.        |
|                    |                           | Higher frame rate possible in row windowing     |
|                    |                           | mode.                                           |
| Timing generation  | On-chip                   | Possibility to control exposure time through    |
|                    |                           | external pin.                                   |
| PGA                | Yes                       | 4 analog gain settings                          |
| Programmable       | Sensor                    | Window coordinates, Timing parameters, Gain     |
| Registers          | parameters                | & offset, Exposure time, flipped readout in X   |
|                    |                           | and Y direction                                 |
| Supported HDR      | Multi-frame               | Successive frames are read out with increasing  |
| modes              | readout with              | exposure times. The final image is a            |
|                    | different                 | combination (externally) of these frames.       |
|                    | exposure time             |                                                 |
|                    |                           |                                                 |
|                    | Interleaved               | Interleaved exposure times for different rows:  |
|                    | integration times         | Odd rows (double rows for color) have a         |
|                    |                           | different exposure compared to even rows        |
|                    |                           | (double rows for color). Final image is a       |
|                    |                           | combination of the two (through                 |
|                    |                           | interpolation).                                 |
|                    |                           |                                                 |



| Specification    | Value            | Comment                                            |  |  |
|------------------|------------------|----------------------------------------------------|--|--|
|                  | Piecewise linear | Response curve with two knee points.               |  |  |
|                  | response         |                                                    |  |  |
| ADC              | 10 bit/12bit     | Column ADC                                         |  |  |
| Interface        | LVDS             | Serial output data + synchronization signals       |  |  |
| I/O logic levels | LVDS = 1.8V      |                                                    |  |  |
|                  | Dig. I/O = 3.3V  |                                                    |  |  |
| Supply voltages  | 2.0V             | LVDS, ADC                                          |  |  |
|                  | 3.0V             | Pixel array supply                                 |  |  |
|                  | 3.3 V            | Dig. I/O, SPI, PGA                                 |  |  |
| Clock inputs     | CLK_IN           | Between 5 and 48MHz                                |  |  |
|                  | LVDS_CLK_N/P     | Between 50 and 480MHz, LVDS                        |  |  |
|                  | SPI_CLK          | Max. 48MHz                                         |  |  |
| Power            | 650 mW           | Maximum over whole operating range                 |  |  |
| Package          | Ceramic package  | Custom ceramic µPGA ( 95 pins )                    |  |  |
| Operating range  | -30C to +70C     | Dark current and noise performance will            |  |  |
|                  |                  | degrade at higher temperature                      |  |  |
| Cover glass      | D263             | Plain glass, no IR cut-off filter on color devices |  |  |
| ESD              | Class 1A HBM     |                                                    |  |  |
|                  | Class 4C CDM     |                                                    |  |  |
| RoHS             | Compliant        |                                                    |  |  |



# 12 ORDERING INFO

| Part Number     | Epi Thickness | Chroma    | Microlens | Package          | Glass |
|-----------------|---------------|-----------|-----------|------------------|-------|
| CMV4000-2E5M1PP | 5 μm          | mono      | yes       | ceramic 95p μPGA | plain |
| CMV4000-2E5C1PP | 5 μm          | RGB Bayer | yes       | ceramic 95p μPGA | plain |
| CMV4000-E12M1PP | 12μm          | mono      | yes       | ceramic 95p μPGA | plain |

On request the package and cover glass can be customized. For options, pricing and delivery time please contact <a href="mailto:info@cmosis.com">info@cmosis.com</a>



## 13 HANDLING AND SOLDERING PROCEDURE

### 13.1 SOLDERING

### 13.1.1 MANUAL SOLDERING

Use partial heating method and use a soldering iron with temperature control. The soldering iron tip temperature is not to exceed 350°C with 270°C maximum pin temperature, 2 seconds maximum duration per pin. Avoid global heating of the ceramic package during soldering. Failure to do so may alter device performance and reliability.

### 13.1.2 WAVE SOLDERING

Wave soldering is possible but not recommended. Solder dipping can cause damage to the glass and harm the imaging capability of the device. See the figure below for the wave soldering profile.



Figure 55: Wave solder profile

### 13.1.3 REFLOW SOLDERING

The figure below shows the maximum recommended thermal profile for a reflow soldering system. If the temperature/time profile exceeds these recommendations, damage to the image sensor can occur.



Figure 56: Reflow solder profile

### 13.1.4 SOLDERING RECOMMENDATIONS

Image sensors with filter arrays (CFA) and micro-lens are especially sensitive to high temperatures. Prolonged heating at elevated temperatures may result in deterioration of the performance of the sensor. Best solution will be flow soldering or manual soldering of a socket (through hole or BGA) and plug in the sensor at latest stage of the assembly/test process. The BGA solution allows more flexibility for the routing of the camera PCB.

### 13.2 HANDLING IMAGE SENSORS

### 13.2.1 ESD

The following are the recommended minimum ESD requirements when handling image sensors.

- 1. Ground workspace (tables, floors...)
- 2. Ground handling personnel (wrist straps, special footwear...)
- 3. Minimize static charging (control humidity, use ionized air, wear gloves...)

### 13.2.2 GLASS CLEANING

When cleaning of the cover glass is needed we recommend the following two methods.

- 1. Blowing off the particles with ionized nitrogen
- 2. Wipe clean using IPA (isopropyl alcohol) and ESD protective wipes.

### 13.2.3 IMAGE SENSOR STORING

Image sensors should be stored under the following conditions

- 1. Dust free
- 2. Temperature 20°C to 40°C
- 3. Humidity between 30% and 60%.
- 4. Avoid radiation, electromagnetic fields, ESD, mechanical stress



# 14 EVALUATION KIT

We have an evaluation kit for the CMV2000 available, which you can rent or buy. This kit consists of a PCB with a ZIF connector for easily changing sensors, a lens mount all in a sturdy metal box with universal tripod adapter. Also CameraLink cables and a PC with a framegrabber and demo software are equipped. This way you can evaluate the sensor's performance. For more detail you can contact info@cmosis.com



# 15 Additional Information

For any additional question related to the operation and specification of the CMV4000 imagers or feedback with respect to the present data sheet please contact techsupport@cmosis.com.